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CHAPTER 1 
INTRODUCTION 



Accompanying the introduction of microprocessors 
such as the 8080, 8085, and 8086 there has been a 
rapid proliferation of intelligent peripheral devices. 
These special purpose peripherals extend CPU per- 
formance and flexibility in a number of important 
ways. 

Table 1-1. Intelligent Peripheral Devices 



8255 (GPIO) 


Programmable Peripheral 
Interface 


8251 (USART) 


Programmable 
Communication Interface 


8253 (TIMER) 


Programmable Interval Timer 


8257 (DMA) 


Programmable DMA Controller 


8259 


Programmable Interrupt 
Controller 


8272 (DDFDC) 


Programmable Floppy Disk 
Controller 


8273 (SDLC) 


Programmable Synchronous 
Data Link Controller 


8275 (CRT) 


Programmable CRT 
Controller 


8279 (PKD) 


Programmable 
Keyboard/Display Controller 


8291, 8292, 8293 


Programmable GPIB System 
Talker, Listener, Controller 



Intelligent devices like the 8272 floppy disk control- 
ler and 8273 synchronous data link controller (see 
Table 1-1) can preprocess serial data and perform 
control tasks which off-load the main system proces- 
sor. Higher overall system throughout is achieved 
and software complexity is greatly reduced. The in- 
telligent peripheral chips simplify master processor 
control tasks by performing many functions exter- 
nally in peripheral hardware rather than internally 
in main processor software. 

Intelligent peripherals also provide system flexibil- 
ity. They contain on-chip mode registers which are 
programmed by the master processor during system 
initialization. These control registers allow the pe- 
ripheral to be configured into many different oper- 
ation modes. The user-defined program for the 
peripheral is stored in main system memory and is 
transferred to the peripheral's registers whenever a 
mode change is required. Of course, this type of 
flexibility requires software overhead in the master 
system which tends to limit the benefit derived form 
the peripheral chip. 

In the past, intelligent peripherals were designed to 
handle very specialized tasks. Separate chips were 



designed for communication disciplines, parallel 
I/O, keyboard encoding, interval timing, CRT con- 
trol, etc. Yet, in spite of the large number of devices 
available and the increased flexibility built into 
these chips, there is still a large number of micro- 
computer peripheral control tasks which are not 
satisfied. 

With the introduction of the Universal Peripheral 
Interface (UPI) microcomputer, Intel has taken the 
intelligent peripheral concept a step further by 
providing an intelligent controller that is fully user 
programmable. It is a complete single-chip micro- 
computer which can connect directly to a master 
processor data bus. It has the same advantages of in- 
telligence and flexibility which previous peripheral 
chips offered. In addition, the UPI is user-program- 
mable: it has IK bytes of ROM or EPROM memory 
for program storage plus 64 bytes of RAM memory 
for data storage or initialization from the master 
processor. The UPI device allows a designer to fully 
specify his control algorithm in the peripheral chip 
without relying on the master processor. Devices like 
printer controllers and keyboard scanners can be 
completely self-contained, relying on the master 
processor only for data transfer. 

The UPI family consists of three components: 

• 8741A microcomputer with EPROM memory 

• 8041A microcomputer with ROM memory 

• 8243 I/O expander device 

The 8741A and 8041A single chip microcomputers 
are functionally equivalent except for the type of 
program memory available with each. These devices 
have the following main features: 



8-bit CPU 

8-bit data bus interface registers 

IK by 8 bit ROM or EPROM memory 

64 by 8 bit RAM memory 

Interval timer/event counter 

Two 8-bit TTL compatible I/O ports 

Resident clock oscillator 



The 8243 device is an I/O multiplexer which allows 
expansion of I/O to over 100 lines (if seven devices 
are used). All three parts are fabricated with N- 
channel MOS technology and require a single, 5V 
supply for operation. 
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Figure 1-1. Interfacing Peripherals To Microcomputer Systems 



INTERFACE REGISTERS FOR MULTI- 
PROCESSOR CONFIGURATIONS 

In the normal configuration, the 8041A/8741A inter- 
faces to the system bus, just like any intelligent pe- 
ripheral device (see Figure 1-1). The host processor 
and the 8041A/8741A form a loosely coupled multi- 
processor system, that is, communications between 
the two processors are direct. Common resources are 
three addressable registers located physically on the 
8041A/8741A. These registers are the Data Bus 
Buffer Input (DBBIN), Data Bus Buffer Output 
(DBBOUT), and Status (STATUS) registers. The 
host processor may read data from DBBOUT or 
write commands and data into DBBIN. The status 
of DBBOUT and DBBIN plus user-defined status is 
supplied in STATUS. The host may read STATUS 
at any time. An interrupt to the UPI processor is 
automatically generated (if enabled) when DBBIN 
is loaded. 

Because the UPI contains a complete microcom- 
puter with program memory, data memory, and 
CPU it can function as a "Universal" controller. A 
designer can program the UPI to control printers, 
tape transports, or multiple serial communication 
channels. The UPI can also handle off-line arithme- 
tic processing, or any number of other low speed con- 
trol tasks. 

POWERFUL 8-BIT PROCESSOR 

The UPI contains a powerful, 8-bit CPU with 2.5 
/tsec cycle time and two single-level interrupts. Its 



instruction set includes over 90 instructions for easy 
software development. Most instructions are single 
byte and single cycle and none are more than^two 
bytes long. The instruction set is optimized for bit 
manipulation and I/O operations. Special instruc- 
tions are included to allow binary or BCD arithmetic 
operations, table lookup routines, loop counters, and 
N-way branch routines. 



c 




D 








<^ 


C 


v^ 


3 


c 




H 


C 




3 


c 




D 


c 




3 


c 




3 


c 




3 


c 




H 


c 


gi 


3 


c 




3 


c 


■ 8741A 


3 


c 
c 




D 
3 


c 
c 
c 




■ XXXX 




3 
3 
3 




, \Mr// . 




g 




a 


c 


I 8041A 

■ xxxx 


D 


c 








3 


c 
c 
c 
c 


3 
3 
3 
3 


c 
c 
c 
c 




< 








IJ 
3 
3 
3 


/M"^ 






c 




Z3 


c 




D 


c 




3 


c 




3 


c 




3 


c 




3 


c 




3 


c 




3 


c 




3 


c 




3 


c 




3 


c 




3 


8041 A 




8741A 






MASK 




ELECTRICALLY 




PROGRAMMED 




PROGRAMMABLE 




ROM 




LIGHT ERASABLE 
EPROM 



Figure 1-2. Pin Compatible ROM/EPROM Versions 
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SPECIAL INSTRUCTION SET 
FEATURES 

• For Loop Counters: 

Decrement Register and Jump if not 
zero. 

• For Bit Manipulation: 

AND to A (immediate data or Register) 
OR to A (immediate data or Register) 
XOR to A (immediate data or Register) 
AND to Output Ports (Accumulator) 
OR to Output Ports (Accumulator) 
Jump Conditionally on any bit in A 

• For BDC Arithmetic: 

Decimal Adjust A 

Swap 4-bit Nibbles of A 

Exchange lower nibbles of A and Register 

Rotate A left or right with or without 

Carry 

• For Lookup Tables: 

Load A from Page of ROM (Address in A) 
Load A from Current Page of ROM 
(Address in A) 

Features for Peripheral Control 

The UPI 8-bit interval timer/event counter can be 
used to generate complex timing sequences for con- 
trol applications or it can count external events such 
as switch closures and position encoder pulses. Soft- 
ware timing loops can be simplified or eliminated by 
the interval timer. If enabled, an interrupt to the 
CPU will occur when the timer overflows. 

The UPI I/O complement contains two TTL-com- 
patible 8-bit bidirectional I/O ports and two general- 
purpose test inputs. Each of the 16 port lines can 
individually function as either input or output under 



software control. Four of the port lines can also func- 
tion as an interface for the 8243 I/O expander which 
provides four additional 4 -bit ports that are directly 
addressable by UPI software. The 8243 expander al- 
lows low cost I/O expansion for large control applica- 
tions while maintaining easy and efficient software 
port addressing. 
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Figure 1-4. 8243 I/O Expander Interface 

On-Chip Memory 

The UPI's 64 bytes of data memory include dual 
working register banks and an 8-level program 
counter stack. Switching between the register banks 
allows fast response to interrupts. The stack is used 
to store return addresses and processor status upon 
entering a subroutine. 

The UPI program memory is available in two types 
to allow flexibility in moving from design to proto- 
type to production with the same PC layout. The 
8741A device with EPROM memory is very eco- 
nomical for initial system design and development. 
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Figure 1-3. Interfaces And Protocols For Multiprocessor Systems 
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Its program memory can be electrically programmed 
using the Intel Universal PROM Programmer. 
When changes are needed, the entire program can be 
erased using UV lamp and reprogrammed in about 
20 minutes. This means the 8741A can be used as a 
single chip "breadboard" for very complex interface 
and control problems. After the 8741A is pro- 
grammed it can be tested in the actual production 
level PC board and the actual functional environ- 
ment. Changes required during system debugging 
can be made in the 8741A program much more easily 
than they could be made in a random logic design. 
The system configuration and PC layout can remain 
fixed during the development process and the turn 
around time between changes can be reduced to a 
minimum. 

At any point during the development cycle, the 
8741A EPROM part can be replaced with the low 
cost 8041A part with factory mask programmed 
memory. The transition from system development 
to mass production is made smoothly because the 
8741A and 8041A parts are completely pin compati- 
ble. This feature allows extensive testing with the 
EPROM part, even into initial shipments to custom- 
ers. Yet, the transition to low-cost ROM is simplified 
to the point of being merely a package substitution. 

PREPROGRAMMED UPl's 

The 8292, 8294, and 8295 are 8041A's that are pro- 
grammed by Intel and sold as standard peripherals. 



The 8292 is a GPIB controller, part of a three chip 
GPIB system. The 8294 is a Data Encryption Unit 
that implements the National Bureau of Standards 
data encryption algorithm. The 8295 is a dot matrix 
printer controller designed especially for the LRC 
7040 series dot matrix impact printers. These parts 
illustrate the great flexibility offered by the UPI 
family. 

DEVELOPMENT SUPPORT 

The UPI microcomputer is fully supported by Intel 
with development tools like the UPP PROM pro- 
grammer already mentioned. An ICE-41A in-circuit 
emulator is also available to allow UPI software and 
hardware to be developed easily and quickly. The 
combination of device features and Intel develop- 
ment support make the UPI an ideal component for 
low-speed peripheral control applications. 

UPI DEVELOPMENT SUPPORT 

• 8048/8041A Assembler 

• Universal PROM Programmer UPP Series 

• ICE-41A Module 

• MULTI-ICE 

• Insite User's Library 

• Application Engineers 

• Training Courses 
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CHAPTER 2 
FUNCTIONAL DESCRIPTION 



The UPI-41A microcomputer is an intelligent pe- 
ripheral controller designed to operate in MCS-86, 
MCS-85, MCS-80, and MCS-48 systems. The UPI'S 
architecture, illustrated in Figure 2-1, is based on a 
low cost, single -chip microcomputer with program 
memory, data memory, CPU, I/O, event timer and 
clock oscillator in a single 40-pin package. Special 
interface registers are included which enable the 
UPI to function as a peripheral to an 8-bit master 
processor. 

This chapter provides a basic description of the UPI 
microcomputer and its system interface registers. 
Unless otherwise noted the descriptions in this sec- 



tion apply to both the 8741A (with UV erasable pro- 
gram memory) and the 8041A (with factory mask 
programmed memory). These two devices are so 
similar that they can be considered identical under 
most circumstances. All functions described in this 
chapter apply to both the 8041A and 8741A. 



PIN DESCRIPTION 

The 8741A and 8041A are packaged in 40-pin Dual 
In-Line (DIP) packages. The pin configuration for 
both devices is shown in Figure 2-2. Figure 2-3 illus- 
trates the UPI Logic Symbol. 
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Figure 2-1. UPI-41A Single Chip Microcomputer 
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Figure 2-2. Pin Configuration 



Figure 2-3. Logic Symbol 



The following section summarizes the functions of 
each UPI-41A pin. NOTE that several pins have two 



or more functions which are described in separate 
paragraphs. 



Table 2-1. Pin Description 



Symbol 


Pin No. 


Type 


Name and Function 


D0-D7 
(BUS) 


12-19 


I/O 


Data Bus: Three-state, bidirectional DATA BUS BUFFER lines used to interface the 
UPI-41A microcomputer to an 8-bit master system data bus. 


P1O-P17 


27-34 


I/O 


Port 1: 8-bit, PORT 1 quasi-bidirectional I/O lines. 


P20-P27 


21-24 
35-38 


I/O 


Port 2: 8-bit, PORT 2 quasi-bidirectional I/O lines. The lower 4 bits (P20-P23) inter- 
face directly to the 8243 I/O expander device and contain address and data information 
during PORT 4-7 access. The upper 4 bits (P24-P27) can be programmed to provide 
interrupt Request and DMA Handshake capability. Software control can configure P24 
as Output Buffer Full (OBF) interrupt, P9.^ as Input Buffer Full (IBF) interrupt, P9fi 
as DMA Request (DRQ), and P27 as DMA ACKnowledge (DACK). 


WR 


10 


I 


Write: I/O write input which enables the master CPU to write data and command 
words to the UPI-41A INPUT DATA BUS BUFFER. 


RD 


8 


I 


Read: I/O read input which enables the master CPU to read data and status words 
from the OUTPUT DATA BUS BUFFER or status register. 


CS 


6 


I 


Chip Select: Chip select input used to select one UPI-41A microcomputer out of sev- 
eral connected to a common data bus. 


Ao 


9 


I 


Command/Data Select: Address input used by the master processor to indicate 
whether bj^e transfer is data (Ao=0) or command (Ao=l). 


TEST 0, 
TESTl 


3^9 


I 


Test Inputs: Input pins which can be directly tested using conditional branch instruc- 
tions. 

Frequency Reference: TEST 1 (Ti) also functions as the event timer input (under 
software control). TEST (Tq) is used during PROM programming and verification in 
the 8741A. 
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Table 2-1. Pin Description (Continued) 


Symbol 


Pin No. 


Type 


Name and Function 


XTAL 1, 
XTAL 2 


2 
3 


I 


Inputs: Inputs for a crystal, LC or an external timing signal to determine the internal 
oscillator frequency. 


SYNC 


11 





Output Clock: Output signal which occurs once per UPI-41A instruction cycle. SYNC 
can be used as a strobe for external circuitry; it is also used to synchronize single step 
operation. 


EA 


7 


I 


External Access: External access input which allows emulation, testing and PROM/ 
ROM verification. 


PROG 


25 


I/O 


Program: Multifunction pin used as the program pulse input during PROM program- 
ming. 

During I/O expander access the PROG pin acts as an address/data strobe to the 8243. 


RESET 


4 


I 


Reset: Input used to reset status flip-flops and to set the program counter to zero. 


RESET is also used during PROM programming and verification. 


SS 


5 


I 


Single Step: Single step input used in the 8741A in conjunction with the SYNC out- 
put to step the program through each instruction. 


vcc 


40 




Power: +5V main power supply pin. 


vdd 


26 




Power: +5V during normal operation. +25V during programming operation. Low 
power standby pin in ROM version. 


vss 


20 




Ground: Circuit ground potential. 



The following sections provide a detailed functional lustrates the functional blocks within the UPI de- 

description of the UPI microcomputer. Figure 2-4 il- vice. 
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Figure 2-4. UPI-41A™ Blocic Diagram 
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CPU SECTION 

The CPU section of the UPI-41A microcomputer 
performs basic data manipulations and controls data 
flow throughout the single chip computer via the in- 
ternal 8-bit data bus. The CPU section includes the 
following functional blocks shown in Figure 2-4: 

• Arithmetic Logic Unit (ALU) 

• Instruction Decoder 

• Accumulator 



Arithmetic Logic Unit (ALU) 

The ALU is capable of performing the following op- 
erations: 

• ADD with or without carry 

• AND, OR, and EXCLUSIVE OR 

• Increment, Decrement 

• Bit complement 

• Rotate left or right 

• Swap 

• BCD decimal adjust 

In a typical operation data from the accumulator is 
combined in the ALU with data from some other 
source on the UPI-41A internal bus (such as a regis- 
ter or an I/O port). The result of an ALU operation 
can be transferred to the internal bus or back to the 
accumulator. 

If an operation such as an ADD or ROTATE re- 
quires more than 8 bits, the CARRY flag is used as 
an indicator. Likewise, during decimal adjust and 
other BCD operations the AUXILIARY CARRY 
flag can be set and acted upon. These flags are part 
of the Program Status Word (PSW). 

Instruction Decoder 

During an instruction fetch, the operation code (op- 
code) portion of each program instruction is stored 
and decoded by the instruction decoder. The de- 
coder generates outputs used along with various tim- 
ing signals to control the functions performed in the 
ALU. Also, the instruction decoder controls the 
source and destination of ALU data. 

Accumulator 

The accumulator is the single most important regis- 
ter in the processor. It is the primary source of data 
to the ALU and is often the destination for results as 
well. Data to and from the I/O ports and memory 
normally passes through the accumulator. 

PROGRAM MEMORY 

The UPI-41A microcomputer has 1024 8-bit words 
of resident, read-only memory for program storage. 
Each of these memory locations is directly address- 
able by a 10-bit program counter. Depending on the 



type of application and the number of program 
changes anticipated, two types of program memory 
are available: 

• 8041A with mask programmed ROM Memory 

• 8741A with electrically programmable 
EPROM Memorv 

The 8041A and 8741A are functionally identical 
parts and are completely pin compatible. The 8041A 
has ROM memory which is mask programmed to 
user specification during fabrication. The 8741A is 
electrically programmed by the user using the Uni- 
versal PROM Programmer (UPP series) with a 
UPP-848 Personality Card. It can be erased using ul- 
traviolt light and reprogrammed at any time. 

A program memory map is illustrated in Figure 2-5. 
Memory is divided into 256 location 'pages' and 
three locations are reserved for special use: 
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Figure 2-5. Program Memory Map 

INTERRUPT VECTORS 

1) Location 

Following a RESET input to the processor, the 
next instruction is automatically fetched from 
location 0. 

2) Location 3 

An interrupt generated by an Input Buffer Full 
(IBF) condition (when the IBF interrupt is en- 
abled) causes the next instruction to be fetched 
from location 3. 
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3) Location 7 

A timer overflow interrupt (when enabled) will 
cause the next instruction to be fetched from lo- 
cation 7. 



Following a system RESET, program execution be- 
gins at location 0. Instructions in program memory 
are normally executed sequentially. Program control 
can be transferred out of the main line of code by an 
input buffer full (IBF) interrupt or a timer inter- 
rupt, or when a jump or call instruction is encoun- 
tered. An IBF interrupt (if enabled) will 
automatically transfer control to location 3 while a 
timer interrupt will transfer control to location 7. 

All conditional JUMP instructions and the indirect 
JUMP instruction are limited in range to the current 
256-location page (that is, they alter PC bits 0-7 
only). If a conditional JUMP or indirect JUMP be- 
gins in location 255 of a page, it must reference a des- 
tination on the following page. 

Program memory can be used to store constants as 
well as program instructions, the UPI-41A instruc- 
tion set contains an instruction (M0VP3) designed 
specifically for efficient transfer of look-up table in- 
formation from page 3 of memory. 

DATA MEMORY 

The UPI-41A universal peripheral interface has 64 
8-bit words of random access data memory. This 
memory contains two working register banks, an 8- 
level program counter stack and a scratch pad mem- 
ory, as shown in Figure 2-6. The amount of scratch 
pad memory available is variable depending on the 
number of addresses nested in the stack and the 
number of working registers being used. 

Addressing Data Memory 

The first eight locations in RAM are designated as 
working registers R0-R7. These locations (or regis- 
ters) can be addressed directly by specifying a regis- 
ter number in the instruction. Since these locations 
are easily addressed, they are generally used to store 
frequently accessed intermediate results. Other lo- 
cations in data memory are addressed indirectly by 
using Ro or Ri to specify the desired address. Since 
all RAM locations (including the eight working reg- 
isters) can be addressed by 6 bits, the two most sig- 
nificant bits (6 and 7) of the addressing registers are 
ignored. 

Working Registers 

Dual banks of eight working registers are included in 
the UPI-41A data memory. Locations 0-7 make up 
register b ank an d locations 24-31 form register 
bank 1. A RESET signal automatically selects regis- 
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Figure 2-6. Data Memory Map 

ter bank 0. When bank is selected, references to 
R0-R7 in UPI-41A instructions operate on locations 
0-7 in data memory. A "select register bank" in- 
struction is used to select between the banks during 
program execution. If the instruction SEL RBI (Se- 
lect Register Bank 1) is executed, then program re- 
ferences to R0-R7 will operate on locations 24-31. 
As stated previously, registers and 1 in the active 
register bank are used as indirect address registers 
for all locations in data memory. 

Register bank 1 is normally reserved for handling in- 
terrupt service routines, thereby preserving the con- 
tents of the main program registers. The SEL RBI 
instruction can be issued at the beginning of an in- 
terrupt service routine. Then, upon return to the 
main program, an RETR (return & restore status) 
instruction will automatically restore the previously 
selected bank. During interrupt processing, registers 
in bank can be accessed indirectly using Rq' and 

Ri: 

If register bank 1 is not used, registers 24-31 can still 
serve as additional scratch pad memory. 

Program Counter Stack 

RAM locations 8-23 are used as an 8-level program 
counter stack. When program control is temporarily 
passed from the main program to a subroutine or in- 
terrupt service routine, the 10-bit program counter 
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and bits 4-7 of the program status word (PSW) are 
stored in two stack locations. When control is re- 
turned to the main program via an RETR instruc- 
tion, the program counter and PSW bits 4-7 are 
restored. Returning via an RET instruction does not 
restore the PSW bits, however. The program counter 
stack is addressed by three stack pointer bits in the 
PSW (bits 0-2). Operation of the program counter 
stack and the program status word is explained in 
detail in the following sections. 

The stack allows up to eight levels of subroutine 
^nesting'; that is, a subroutine may call a second sub- 
routine, which may call a third, etc., up to eight lev- 
els. Unused stack locations can be used as scratch 
pad memory. Each unused level of subroutine nest- 
ing provides two additional RAM locations for gen- 
eral use. 

The following sections provide a detailed descrip- 
tion of the Program Counter Stack and the Program 
Status Word. 

PROGRAM COUNTER 

The UPI-41A microcomputer has a 10-bit program 
counter (PC) which can directly address any of the 
1024 locations in program memory. The program 
counter always contains the address of the next in- 
struction to be executed and is normally increment- 
ed sequentially for each instruction to be executed 
when each instruction fetches occurs. 

When control is temporarily passed from the main 
program to a subroutine or an interrupt routine, 
however, the PC contents must be altered to point to 
the address of the desired routine. The stack is used 
to save the current PC contents so that, at the end of 
the routine, main program execution can continue. 
The pro gram counter is initialized to zero by a 
RESET signal. 

PROGRAM COUNTER STACK 

The Program Counter Stack is composed of 16 loca- 
tions in Data Memory as illustrated in Figure 2-7. 
These RAM locations (8 through 23) are used to 
store the 10-bit program counter and 4 bits of the 
program status word. 

An interrupt or CALL to a subroutine causes the 
contents of the program counter to be stored in one 
of the 8 register pairs of the program counter stack. 

A 3 -bit Stack Pointer which is part of the Program 
Status Word (PSW) determines the stack pair to be 
used at a give n time. The stack pointer is initialized 
by a RESET signal to OOH which corresponds to 
RAM locations 8 and 9. 
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Figure 2-7. Program Counter Stack 



The first call or interrupt results in the program 
counter and PSW contents being transferred to 
RAM locations 8 and 9 in the format shown in Figure 
2-7. The stack pointer is automatically incremented 
by 1 to point to locations 10 and 11 in anticipation of 
another CALL. 

Nesting of subroutines within subroutines can con- 
tinue up to 8 levels without overflowing the stack. If 
overflow does occur the deepest address stored (lo- 
cations 8 and 9) will be overwritten and lost since the 
stack pointer overflows from 07H to OOH. Likewise, 
the stack pointer will underflow from OOH to 07H. 

The end of a subroutine is signaled by a return in- 
struction, either RET or RETR. Each instruction 
will automatically decrement the Stack Pointer and 
transfer the contents of the proper RAM register 
pair to the Program Counter. 

PROGRAM STATUS WORD 

The 8-bit program status word illustrated in Figure 
2-8 is used to store general information about pro- 
gram execution. In addition to the 3-bit Stack Point- 
er discussed previously, the PSW includes the 
following flags: 



• CY 


— Carry 


• AC 


— Auxiliary Carry 


• Fo 


— Flag 


• BS 


— Register Bank Select 
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Figure 2-8. Program Status Word 

The Program Status Word (PSW) is actually a col- 
lection of flip-flops located throughout the machine 
which are read or written as a whole. The PSW can 
be loaded to or from the accumulator by the MOV A, 
PSW or MOV PSW,A instructions. The ability to 
write directly to the PSW allows easy restoration of 
machine status after a power-down sequence. 

The upper 4 bits of the PSW (bits 4, 5, 6, and 7) are 
stored in the PC Stack with every subroutine CALL 
or interrupt vector. Restoring the bits on a return is 
optional. The bits are restored if an RETR instruc- 
tion is executed, but not if an RET is executed. 



Bits 
Bit 4 



Bits 



PSW bit definitions are as follows: 

• Bits 0-2 Stack Pointer Bits So, Si, S2 
Not Used 
Working Register Bank 

= Bank 

1 = Bank 1 
Flag bit (Fo) 

This is a general purpose flag 
which can be cleared or comple- 
mented and tested with condi- 
tional jump instructions. It may 
be used during data transfer to 
an external processor. 
Auxiliary Carry (AC) 
The flag status is determined by 
an ADD instruction and is used 



Bite 



by the Decimal Adjustment in- 
struction DAA. 
• Bit 7 Carry (CY) 

The flag indicates that a previous 
operation resulted in overflow of 
the accumulator. 

CONDITIONAL BRANCH LOGIC 

Conditional Branch Logic in the UPI-41A allows the 
status of various processor flags, inputs, and other 
hardware functions to directly affect program execu- 
tion. The status is sampled in state 3 of the first 
cycle. 

Table 2-2 lists the internal conditions which are test- 
able and indicates the condition which will cause a 
jump. In all cases, the destination address must be 
within the page of program memory (256 locations) 
in which the jump instruction occurs. 

OSCILLATOR AND TIMING CIRCUITS 

The 8041A's internal timing generation is controlled 
by a self-contained oscillator and timing circuit. A 
choice of crystal, L-C or external clock can be used to 
derive the basic oscillator frequency. 

The resident timing circuit consists of an oscillator, 
a state counter and a cycle counter as illustrated in 
Figure 2-9. Figure 2-10 shows instruction cycle 
timing. 

Oscillator 

The on-board oscillator is a series resonant circuit 
with a frequency range of 1 to 6 MHz. Pins XTAL 1 
and XTAL 2 are input and output (respectively) of a 
high gain amplifier stage. A crystal or inductor and 
capacitor connected between XTAL 1 and XTAL 2 
provide the feedback and proper phase shift for os- 



Table 2-2. Conditional Branch instructions 







Jump Condition 


Device 


Instruction Mnemonic 


Jump if: 


Accumulator 


JZ 


addr 


All bits zero 




JNZ 


addr 


Any bit not zero 


Accumulator bit 


JBb 


addr 


Bit "b" = 1 


Carry flag 


JC 


addr 


Carry flag = 1 




JNC 


addr 


Carry flag = 


User flag 


JFO 


addr 


Fo flag = 1 




JFl 


addr 


Fi flag = 1 


Timer flag 


JTF 


addr 


Timer flag = 1 


Test Input 


JTO 


addr 


To = l 




JNTO 


addr 


To = 


Test Input 1 


JTl 


addr 


Ti = l 




JNTl 


addr 


Ti = 


Input Buffer flag 


JNIBF 


addr 


IBF flag = 


Output Buffer flag 


JOBF 


addr 


OBF flag = 1 
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Figure 2-9. Oscillator Configuration 
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Figure 2-10. Instruction Cycle Timing 



cillation. Recommended connections for crystal or 
L-C are shown in Figure 2-11. 

State Counter 

The output of the oscillator is divided by 3 in the 
state counter to generate a signal which defines the 
state times of the machine. 

Each instruction cycle consists of five states as illus- 
trated in Figure 2-10 and Table 2-3. The overlap of 



address and execution operations illustrated in Fig- 
ure 2-10 allows fast instruction execution. 

Cycle Counter 

The output of the state counter is divided by 5 in the 
cycle counter to generate a signal which defines a 
machine cycle. This signal is call SYNC and is avail- 
able continously on the SYNC output pin. It can be 
used to synchronize external circuitry or as a general 
purpose clock output. It is also used for synchroniz- 
ing single-step in the 8741A. 



Table 2-3. Instruction Timing Diagram 
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Figure 2-11. Recommended Crystal and L-C Connections 



Frequency Reference 

The external crystal provides high speed and accu- 
rate timing generation. A crystal frequency of 5.9904 
MHz is useful for generation of standard communi- 
cation frequencies by the 8741A and 8041A. How- 
ever, if an accurate frequency reference and maxi- 
mum processor speed are not required, an inductor 
and capacitor may be used in place of the crystal as 
shown in Figure 2-11. 

A recommended range of inductance and capaci- 
tance combinations is given below: 

• L = 130 jLtH corresponds to 3 MHz 

• L = 45 /iH corresponds to 5 MHz 

An external clock signal can also be used as a fre- 
quency reference to the 8741A or 8041A; however, 
the levels are not TTL compatible. The signal must 
be in the 1-6 MHz frequency range and must be con- 
nected to pins XTAL 1 and XTAL 2 by buffers with 
a suitable pull-up resistor to guarantee that a logic 
"1" is above 3.8 volts. The recommended connection 
is shown in Figure 2-12. 
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Figure 2-12. Recommended Connection 
For External Cloci( Signal 



INTERVAL TIMER/EVENT COUNTER 

The 8041A has a resident 8-bit timer/counter which 
has several software selectable modes of operation. 
As an interval timer, it can generate accurate delays 
from 80 microseconds to 20.48 milliseconds without 
placing undue burden on the processor. In the 
counter mode, external events such as switch clo- 
sures or tachometer pulses can be counted and used 
to direct program flow. 

Timer Configuration 

Figure 2-13 illustrates the basic timer /counter con- 
figuration. An 8-bit register is used to count pulses 
from either the internal clock and prescaler or from 
an external source. The counter is presettable and 
readable with two MOV instructions which transfer 
the contents of the accumulator to the counter and 
vice -versa. The counter is initialized solel y by the 
MOV T,A instruction; it is not cle ared by a RESET 
signal. The counter is stopped by a RESET or STOP 
TCNT instruction and remains stopped until re- 
started either as a timer (START T instruction) or 
as a counter (START CNT instruction). Once 
started, the counter will increment to its maximum 
count (FFH) and overflow to zero continuing its 
count un til stopped by a STOP TCNT instruction or 
RESET. 

The increment from maximum count to zero (over- 
flow) results in setting the Timer Flag (TF) and gen- 
erating an interrupt request. The state of the 
overflow flag is testable with the conditional jump 
instruction, JTF. Th e flag is reset by executing a 
JTF or by a RESET signal. 

The timer interrupt request is stored in a latch and 
ORed with the input buffer full interrupt request. 
The timer interrupt can be enabled or disabled inde- 
pendent of the IBF interrupt by the EN TCNTI and 
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Figure 2-13. Timer Counter 



DIS TCTNI instructions. If enabled, the counter 
overflow will cause a subroutine call to location 7 
where the timer service routine is stored. If the timer 
and Input Buffer Full interrupts occur simulta- 
neously, the IBF source will be recognized and the 
call will be to location 3. Since the timer interrupt is 
latched, it will remain pending until the DBBIN reg- 
ister has been serviced and will immediately be rec- 
ognized upon return from the service routine. A 
pending timer interrupt is reset by the initiation of a 
timer interrupt service routine. 

Event Counter Mode 

The START CNT instruction connects the TEST 1 
input pin to the counter input and enables the 
counter. Note that this instruction does not clear the 
counter. The counter is incremented on high to low 
transition of TEST 1. The maximum count rate is 
one count per three instruction cycles (every 7.5 mi- 
croseconds when using a 6 MHz crystal). There is no 
minimum frequency limit. The TEST 1 input must 
remain high for a minimum of 500 ns (at 6 MHz) 
during a count cycle. 

Timer Mode 

The START T instruction connects an internal 
clock to the counter input and enables the counter. 
The input frequency is derived from a divide by 32 
prescaler connected to the 400 kHz machine cycle 
clock. The configuration is illustrated in Figure 2-13. 
The resulting 12.5 kHz clock provides a counter in- 
crement every 80 ^sec. Various delays and timing se- 
quences between 80 fisec and 20.48 msec can easily 
be generated with a miniumum of software timing 



loops. Times longer than 20 msec can be accurately 
measured by accumulating multiple overflows in a 
register under software control. For time resolution 
less than 80 /isec an external clock can be applied to 
the TEST 1 input and the counter can be operated 
in the event counter mode. The 2.5 jusec SYNC out- 
put divided by 3 or more can serve as the external 
clock. Software loops can also be used to "fine tune" 
long delays generated by the timer. 

TEST 1 Event Counter Input 

The TEST 1 pin is multifunctional. It is aut omati- 
cally initialized as a test input by a RESET signal 
and can be tested using UPI-41A conditional branch 
instructions. 

In the second mode of operation, illustrated in Fig- 
ure 2-13, the TEST 1 pin is used as an input to the 
internal 8-bit event counter. The Start Counter 
(STRT CNT) instruction controls an internal switch 
which connects TEST 1 through an edge detector to 
the 8-bit internal counter. Note that this instruction 
does not inhibit the testing of TEST 1 via condition- 
al Jump instructions. 

In the counter mode the TEST 1 input is sampled 
once per instruction cycle. After a high level is de- 
tected, the next occurence of a low level at TEST 1 
will cause the counter to increment by one. 

The event counter functions can be stopped by the 
Stop Timer/Counter (STOP TCNT) instruction. 
When this instruction is executed the TEST 1 pin 



2-10 



FUNCTIONAL DESCRIPTION 



becomes a test input and functions as previously de- 
scribed. 

TEST INPUTS 

There are two multifunction pins designated as Test 
Inputs, TEST and TEST 1. In the normal mode of 
operation, status of each of these lines can be direct- 
ly tested using the following conditional Jump 
instructions: 

• JTO Jump if TEST = 1 

• JNTO Jump if TEST = 

• JTl Jump if TEST 1 = 1 

• JNTl Jump if TEST 1 = 

The test inputs are TTL compatible. An external 
logic signal connnected to one of the test inputs will 
be sampled at the time the appropriate conditional 
jump instruction is executed. The path of program 
execution will be altered depending on the state of 
the external signal when sampled. 

INTERRUPTS 

The 8041A/8741A has the following internal inter- 
rupts: 

• Input Buffer Full (IBF) interrupt 

• Timer Overflow interrupt 



The IBF interrupt forces a CALL to location 3 in 
program memory; a timer-overflow interrupt forces 
a CALL to location 7. The IBF interrupt is enabled 
by the EN I instruction and disabled by the DIS I 
instruction. The timer-overflow interrupt is enabled 
and disabled by the EN TNCTI and DIS TCNTI 
instructions, respectively. 

Figure 2-14 illustrates the internal interrupt l ogic. 
An IBF interrupt request is generated whenever WR 
and CS are both low, regardless of whether inter- 
rupts are enabled. The interrupt request is cleared 
upon entering the IBF service routine only. That is, 
the DIS I instruction does not clear a pending IBF 
interrupt. 

Interrupt Timing Latency 

When the IBF interrupt is enabled and an IBF inter- 
rupt request occurs, an interrupt sequence is initi- 
ated as soon as the currently executing instruction is 
completed. The following sequence occurs: 

• A CALL to location 3 is forced. 

• The program counter and bits 4-7 of the Pro- 
gram Status Word are stored in the stack. 

• The stack pointer is incremented. 
Location 3 in program memory should contain an 
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Figure 2-14. interrupt Logic 
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unconditional jump to the beginning of the IBF in- 
terrupt service routine elsewhere in program mem- 
ory. At the end of the service routine, an RETR 
(Return and Restore Status) instruction is used to 
return control to the main program. This instruction 
will restore the program counter and PSW bits 4-7, 
providing automatic restoration of the previously 
active register bank as well. RETR also re-enables 
interrupts. 

A timer-overflow interrupt is enabled by the EN 
TCNTI instruction and disabled by the DIS TCNTI 
instruction. If enabled, this interrupt occurs when 
the timer/counter register overflows. A CALL to lo- 
cation 7 is forced and the interrupt routine proceeds 
as described above. 

The interrupt service latency is the sum of current 
instruction time, interrupt recognition time, and the 
internal call to the interrupt vector address. The 
worst case latency time for servicing an interrupt is 7 
clock cycles. Best case latency is 4 clock cycles. 

Interrupt Timing 

Interrupt inputs may be enabled or disabled under 
program control using EN I, DIS I, EN T CNTI and 
DIS TCNTI instructions. Also, a RESET input will 
disable interrupts. An interrupt request must be re- 
moved before the RETR instruction is executed to 
return from the service routine, otherwise the pro- 
cessor wil l re-e nter the service routine immediately. 
Thus, the WR and CS inputs should not be held low 
longer than the duration of the interrupt service 
routine. 

The interrupt system is single level. Once an inter- 
rupt is detected, all further interrupt requests are 
latched but are not acted upon until execution of an 
RETR instruction re-enables the interrupt input 
logic. This occurs at the beginning of the second cy- 
cle of the RETR instruction. If an IBF interrupt and 
a timer-overflow interrupt occur simultaneously, the 
IBF interrupt will be recognized first and the timer- 
overflow interrupt will remain pending until the end 
of the interrupt service routine. 

External Interrupts 

An external interrupt can be created using the UPI- 
41A timer/counter in the event counter mode. The 
counter is first preset to FFH and the EN TCNTI 
instruction is executed. A timer-overflow interrupt 
is generated by the first high to low transition of the 
TEST 1 input pin. Also, if an IBF interrupt occurs 
during servicing of the timer/counter interrupt, it 
will remain pending until the end of the service 
routine. 



Host Interrupts And DMA 

If needed, two external interrupts to the host system 
can be created using the EN FLAGS instruction. 
This instruction allocates two I/O lines on PORT 2 
(P24 and P25). P24 is the Output Buffer Full inter- 
rupt request line to the host system; P25 is the Input 
Buffer empty interrupt request line. These interrupt 
outputs reflect the internal status of the OBF flag 
and the IBF inverted flag. Note, these outputs may 
be inhibited by writing a "0" to these pins. Reenab- 
ling interrupts is done by writing a "1" to these port 
pins. Interrupts are typically enabled after power on 
since the I/O ports are set in a "1" condition. The EN 
FLAG'S effect is only cancelled by a device RESET. 

DMA handshaking controls are available from two 
pins on PORT 2 of the UPI-41A microcomputer. 
These lines (P26 and P27) are enabled by the EN 
DMA instruction. P26 becomes DMA request 
( DRQ) and P27 becomes DMA acknowledge 
(DACK). The UPI program initiates a DMA request 
by writing a "1" to P26. The DMA controller trans- 
fers the data into the DBBIN data register using 
DACK which acts as a chip select. The EN DMA in- 
struction can only be cancelled by a chip RESET. 



RESET 



The RESET input on the 8041A/8741A provides a 
means for internal initialization of the processor. An 
automatic initialization pulse can be generated at 
power turn-on s imply by connecting a 1 ixfd capaci- 
tor between the RESET input and ground as shown 
in Figure 2-15. It has an internal pull-up resistor to 
charge the capacitor and a Schmitt-trigger circuit to 
generate a clean transition. 



If an ext ernal RESET pulse is used it must hold the 
RESET input low for at least 10 milliseconds after 
the power supply is within tolerance. Figure 2-15 il- 
lustrates a confi guration u sing an external TTL gate 
to generate the RESET i nput. Th is configuration 
can be used to derive the RESET signal from the 
8224 clock generator in an 8080 system. 



The RESET input performs the following functions: 

• Sets Program Counter to zero. 

• Sets the Stack Pointer to zero 

• Selects Register Bank 

• Sets PORTS 1 and 2 to the Input Mode 

• Disables interrupts. 

• Stops the timer. 

• Clears the timer flag. 

• Clears Fq and Fi flip-flops. 
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Figure 2-15. External Reset Configuration 



DATA BUS BUFFER 

Two 8-bit data bus buffer registers, DBBIN and 
DBBOUT, serve as temporary buffers for commands 
and data flowing between it and the master proces- 
sor. Externally, data is transmitted or received by 
the DBB registers upon execution of an INput or 
OUTput instruction by the master processor. Four 
control signals are used: 

• Ao Address input signifying control or da- 
ta 

• CS^ Chip Select 

• RD Read strobe 

• WR Write strobe 

Transfer can be implemented with or without UPI 
program interference by enabling or disabling an in- 
ternal UPI interrupt. Internally, data transfer be- 



tween the DBB and the UPI accumulator is under 
software control and is completely asynchronous to 
the external processor timing. This allows the UPI 
software to handle peripheral control tasks indepen- 
dent of the main processor while still maintaining a 
data interface with the master system. 

Configuration 

Figure 2-16 illustrates the internal configuration of 
the DBB registers. Data is stored in two 8-bit buffer 
registers, DBBIN and DBBOUT. DBBIN and 
DBBOU T ma y be accessed by the external processor 
using the WR line and the RD line, respectively. The 
data bus is a bidirectional, three-state bus which can 
be connected directly to an 8- bit microprocessor sys- 
tem. Four control lines (WR, RD, CS, Aq) are used 
by the external processor to transfer data to and 
from the DBBIN and DBBOUT registers. 
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An 8-bit register containing status flags is used to 
indicate the status of the DBB registers. The eight 
status flags are defined as follows: 

• OBF Output Buffer Full This flag is auto- 
matically set when the 8041A loads the 
DBBOUT register and is cleared when the mas- 
ter processor reads the data register. 

• IBF Input Buffer Full This flag is set when 
the master processor writes a character to the 
DBBIN register and is cleared when the 8041A 
INputs the data register contents to its accumu- 
lator. 

• Fo This is a general purpose flag which can be 
cleared or toggled under 8041A software control. 
The flag is used to transfer 8041A status infor- 
mation to the master processor. 

• Fi Command/Data This flag is set to the con- 
dition of the Aq input line when the master pro- 
cessor writes a character to the data register. The 
Fi flag can also be cleared or toggled under 
8041A program control. 

• ST4 Through ST7 These bits are user defined 
status bits. They are defined by the MOV STS,A 
instruction. 

All flags in the stat us register are automatically 
cleared by a RESET input. 



SYSTEM INTERFACE 

Figure 2-17 illustrates how an 8041A can be connect- 
ed to a standard 8080-type bus system. Data lines 
D0-D7 form a three-state, bidirectional port which 
can be connected directly to the system data bus. 
The UPI bus interface has sufficient drive capability 
(400 /LtA) for small systems, however, a larger system 
may require buffers. 

Four control signals are required to handle the data 
and s tatus information transfer: 

• WR I/O WRITE signal used to transfer data 

from the system bus to the UPI DBBIN 
register and set the Fi flag in the status 
register. 

• RD I/O READ signal used to transfer data 

from the DBBOUT register or status 
register to the system data bus. 

• CS CHIP SELECT signal used to enable 

one 8041 A out of several connected to a 
common bus. 

• Aq Address input used to select either the 

8-bit status register or DBBOUT regis- 
ter during an I/O READ. 
Also, the signal is used to set the Fi flag 
in the status register during an I/O 
WRITE. 
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The WR and RD signals are active low and are stan- 
dard MCS-80 peripheral control signals used to syn- 
chronize data transfer between the system bus and 
peripheral devices. 

The CS and Aq signals are decoded from the address 
bus of the master system. In a system with few I/O 
devices a linear addressing configuration can be used 
where Ap and Ai lines are connected directly to Aq 
and CS inputs (see Figure 2-17). 

Data Read 

Table 2-4 illustrates the relati ve t iming of a 
DBBOUT Read. When CS, Aq, and RD are low, the 
contents of the DBBOUT register is placed on the 
three-state Data lines D0-D7 and the OBF flag is 
cleared. 



can individually function as either inputs or outputs 
under software control. In addition, the lower 4 lines 
of PORT 2 can be used to interface to an 8243 I/O 
expander device to increase I/O capacity to 28 or 
more lines. The additional lines are grouped as 4-bit 
ports: PORTS 4, 5, 6, and 7. 

PORTS 1 and 2 

PORTS 1 and 2 are each 8 bits wide and have the 
same I/O characteristics. Data written to these ports 
by an OUTL Pp,A instruction is latched and re- 
mains unchanged until it is rewritten. Input data is 
sampled at the time the IN, A,Pp instruction is ex- 
ecuted. Therefore, input data must be present at the 
PORT until read by an INput instruction. PORT 1 
and 2 inputs are fully TTL compatible and outputs 
will drive one standard TTL load. 



The master processor uses CS, Aq, WR, and RD to 
control data transfer between the DBBOUT register 
and the master system. The following operations are 
under master processor control: 

Table 2-4. Data Transfer Controls 
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Read DBBOUT register 
Read STATUS register 
Write DBBIN data register 
Write DBBIN command register 
Disable DBB 



Status Read 

Table 2-4 shows the logic sequence required for a 
STATUS register read. When CS and RD are low 
with Aq high, the contents of the 8-bit status register 
appears on Data lines D0-D7. 

Data Write 

Table 2-4 shows the sequence for writing informa- 
tion to the DBBIN register. When CS and WR are 
low, the contents of the system data bus is latched 
into DBBIN. Also, the IBF flag is set and an inter- 
rupt is generated, if enabled. 

Command Write 

During any write (Table 2-4), the state of the Aq in- 
put is latched into the status register in the Fi (com- 
mand/data) flag location. This additional bit is used 
to signal whether DBBIN contents are command 
(Aq = 1) or data (Aq = 0) information. 

INPUT/OUTPUT INTERFACE 

The UPI-41A has 16 lines for input and output func- 
tions. These I/O lines are grouped as two 8-bit TTL 
compatible ports: PORTS 1 and 2. The port lines 



Circuit Configuration 

The PORT 1 and 2 lines have a special output struc- 
ture (shown in Figure 2-18) that allows each line to 
serve as an input, an output, or both, even though 
outputs are statically latched. 

Each line has a permanent high impedance pull-up 
(50Kfi) which is sufficient to provide source current 
for a TTL high level, yet can be pulled low by a stan- 
dard TTL gate drive. Whenever a "1" is written to a 
line, a low impedance pull-up (5K) is switched in 
momentarily (500 ns) to provide a fast transition 
from to 1. When a "0" is written to the line, a low 
impedance pull-down (30012) is active to provide 
TTL current sinking capability. 

To use a particular PORT pin as an input, a logic "1" 
must first be written to that pin. 



NOTE: A RESET intializes all PORT pins to the 
high impedance logic "1" state. 

An external TTL device connected to the pin has 
sufficient current sinking capability to pull-down 
the pin to the low state. An IN A,Pp instruction will 
sample the status of PORT pin and will input the 
proper logic level. With no external input connected, 
the IN A,Pp instruction inputs the previous output 
status. 

This structure allows input and output information 
on the same pin and also allows any mix of input and 
output lines on the same port. However, when inputs 
and outputs are mixed on one PORT, a PORT write 
will cause the strong internal pull-ups to turn on at 
all inputs. If a switch or other low impedance device 
is connected to an input, a PORT write ("1" to an 
input) could cause current limits on internal lines to 
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Figure 2-18. Quasi-Bidirectional Port Structure 



be exceeded. Figure 2-19 illustrates the recommend- 
ed connection when inputs and outputs are mixed on 
one PORT. 

The bidirectional port structure in combination with 
the UPI-41A logical AND and OR instructions pro- 
vides an efficient means for handling single line in- 
puts and outputs within an 8-bit processor. 

PORTS 4, 5, 6, and 7 

By using an 8243 I/O expander, 16 additional I/O 
lines can be connected to the UPI-41A and directly 
addressed as 4-bit I/O ports using UPI-41A instruc- 
tions. This feature saves program space and design 
time, and improves the bit handling capability of the 
UPI-41A. 



The lower half of PORT 2 provides an interface to 
the 8243 as illustrated in Figure 2-20. The PROG pin 
is used as a strobe to clock address and data informa- 
tion via the PORT 2 interface. The extra 16 I/O lines 
are referred to in UPI software as PORTS 4, 5, 6, and 
7. Each PORT can be directly addressed and can be 
ANDed and ORed with an immediate data mask. 
Data can be moved directly to the accumulator from 
the expander PORTS (or vice-versa). 

The 8243 I/O ports, PORTS 4, 5, 6, and 7, provide 
more drive capability than the UPI-41A bidirec- 
tional ports. The 8243 output is capable of driving 
about 5 standard TTL loads. 
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Figure 2-19. Recommended PORT Input Connections 
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Figure 2-20. 8243 Expander Interface 



Multiple 8243's can be connected to the PORT 2 in- 
terface. In normal operation, only one of the 8243's 
would be active at the time an Input or Output com- 
mand is executed. The upper half of PORT 2 is used 
to provide chip select signals to the 8243's. Figure 2- 
21 shows how four 8243's could be connected. Soft- 



ware is needed to select and set the proper PORT 2 
pin before an INPUT or OUTPUT command to 
PORTS 4-7 is executed. In general, the software 
overhead required is very minor compared to the 
added flexibility of having a large number of I/O 
pins available. 
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Figure 2-21. Multiple 8243 Expansion 
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CHAPTER 3 
INSTRUCTION SET 



The UPI-41A Instruction Set is opcode-compatible 
with the MCS-48 set except for the elimination of 
external program and data memory instructions and 
the addition of the data bus buffer instructions. It is 
very straightforward and efficient in its use of pro- 
gram memory. All instructions are either 1 or 2 bytes 
in length (over 70 % are only 1 byte long) and over 
half of the instructions execute in one machine cycle. 
The remainder require only two cycles and include 
Branch, Immediate, and I/O operations. 

The UPI-41A Instruction Set efficiently handles the 
single -bit operations required in control applica- 
tions. Special instructions allow port bits to be set or 
cleared individually. Also, any accumulator bit can 
be directly tested via conditional branch instruc- 
tions. Additional instructions are included to 
simplify loop counters, table look-up routines and 
N-way branch routines. 

The UPI-41A Microcomputer handles arithmetic 
operations in both binary and BCD for efficient in- 
terface to peripherals such as keyboards and dis- 
plays. 

The instruction set can be divided into the following 
groups: 

• Data Moves 

• Accumulator Operations 

• Flags 

• Register Operations 

• Branch Instructions 

• Control 

• Timer Operations 

• Subroutines 

• Input/Output Instructions 

Data Moves 

(See Instruction Summary) 

The 8-bit accumulator is the control point for all 
data transfers within the UPI-41A. Data can be 
transferred between the 8 registers of each working 
register bank and the accumulator directly (i.e., with 
a source or destination register specified by 3 bits in 
the instruction). The remaining locations in the 
RAM array are addressed either by Rq or Ri of the 
active register bank. Transfers to and from RAM re- 
quire one cycle. 

Constants stored in Program Memory can be loaded 
directly into the accumulator or the eight working 
registers. Data can also be transferred directly be- 
tween the accumulator and the on-board timer/ 
counter, the Status Register (STS), or the Program 
Status Word (PSW). Transfers to the STS register 
alter bits 4-7 only. Transfers to the PSW alter ma- 



chine status accordingly and provide a means of re- 
storing status after an interrupt or of altering the 
stack pointer if necessary. 

Accumulator Operations 

Immediate data, data memory, or the working regis- 
ters can be added (with or without carry) to the ac- 
cumulator. These sources can also be ANDed, ORed, 
or exclusive ORed to the accumulator. Data may be 
moved to or from the accumulator and working reg- 
isters or data memory. The two values can also be 
exchanged in a single operation. 

The lower 4 bits of the accumulator can be ex- 
changed with the lower 4 bits of any of the internal 
RAM locations. This operation, along with an in- 
struction which swaps the upper and lower 4 -bit 
halves of the accumulator, provides easy handling of 
BCD numbers and other 4-bit quantities. To facili- 
tate BCD arithmetic a Decimal Adjust instruction is 
also included. This instruction is used to correct the 
result of the binary addition of two 2-digit BCD 
numbers. Performing a decimal adjust on the result 
in the accumulator produces the desired BCD result. 

The accumulator can be incremented, decremented, 
cleared, or complemented and can be rotated left or 
right 1 bit at a time with or without carry. 

A subtract operation can be easily implemented in 
UPI-41A software using three single-byte, single- 
cycle instructions. A value can be subtracted from 
the accumulator by using the following instructions: 

• Complement the accumulator 

• Add the value to the accumulator 

• Complement the accumulator 

Flags 

There are four user accessible flags: 

• Carry 

• Auxiliary Carry 

• Fo 

• Fi 

The Carry flag indicates overflow of the accumula- 
tor, while the Auxiliary Carry flag indicates overflow 
between BCD digits and is used during decimal ad- 
just operations. Both Carry and Auxiliary Carry are 
part of the Program Status Word (PSW) and are 
stored in the stack during subroutine calls. The Fq 
and Fi flags are general-purpose flags which can be 
cleared or complemented by UPI instructions. Fq is 
accessible via the Program Status Word and is 
stored in the stack with the Carry flags. Fi reflects 
the condition of the Aq line, and caution must be 
used when setting or clearing it. 
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Register Operations 

The working registers can be accessed via the accu- 
mulator as explained above, or they can be loaded 
with immediate data constants from program mem- 
ory. In addition, they can be incremented or decre- 
mented directly, or they can be used as loop counters 
as explained in the section on branch instructions. 

Additional Data Memory locations can be accessed 
with indirect instructions via Rq and Ri. 



Branch Instructions 

The UPI-41A Instruction Set includes 17 jump 
instructions. The unconditional jump instruction al- 
lows jumps anywhere in the IK words of program 
memory. All other jump instructions are limited to 
the current page (256 words) of program memory. 

Conditional jump instructions can test the following 
inputs and machine flags: 

TEST input pin 
TEST 1 input pin 
Input Buffer Full flag 
Output Buffer Full flag 
Timer flag 
Accumulator zero 
Accumulator bit 
Carry flag 
Foflag 
Fiflag 

The conditions tested by these instructions are the 
instantaneous values at the time the conditional 
jump instruction is executed. For instance, the jump 
on accumulator zero instruction tests the accumula- 
tor itself, not an intermediate flag. 

The decrement register and jump if not zero (D JNZ) 
instruction combines decrement and branch oper- 
ations in a single instruction which is useful in im- 
plementing a loop counter. This instruction can 
designate any of the 8 working registers as a counter 
and can effect a branch to any address within the 
current page of execution. 

A special indirect jump instruction (JMPP @A) al- 
lows the program to be vectored to any one of several 
different locations based on the contents of the accu- 
mulator. The contents of the accumulator point to a 
location in program memory which contains the 
jump address. As an example, this instruction could 
be used to vector to any one of several routines based 
on an ASCII character which has been loaded into 
the accumulator. In this way, ASCII inputs can be 
used to initiate various routines. 



Control 

The UPI-41A Instruction Set has six instructions for 
control of the DMA, interrupts, and selection of 
working register banks. 

The UPI-41A provides two instructions for control 
of the external microcomputer system. IBF and 
OBF flags can be routed to PORT 2 allowing inter- 
rupts of the external processor. DMA handshaking 
signals can also be enabled using lines from PORT 2. 

The IBF interrupt can be enabled and disabled us- 
ing two instructions. Also, the interrupt is automati- 
cally disabled following a RESET input or during an 
interrupt service routine. 

The working register bank switch instructions allow 
the programmer to immediately substitute a second 
8 register bank for the one in use. This effectively 
provides either 16 working registers or the means for 
quickly saving the contents of the first 8 registers in 
response to an interrupt. The user has the option of 
switching register banks when an interrupt occurs. 
However, if the banks are switched, the original 
bank will automatically be restored upon execution 
of a return and restore status (RETR) instruction at 
the end of the interrupt service routine. 

Timer 

The 8-bit on-board timer/counter can be loaded or 
read via the accumulator while the counter is 
stopped or while counting. 

The counter can be started as a timer with an inter- 
nal clock source or as an event counter or timer with 
an external clock applied to the TEST 1 pin. The 
instruction executed determines which clock source 
is used. A single instruction stops the counter 
whether it is operating with an internal or an exter- 
nal clock source. In addition, two instructions allow 
the timer interrupt to be enabled or disabled. 

Subroutines 

Subroutines are entered by executing a call instruc- 
tion. Calls can be made to any address in the IK 
word program memory. Two separate return 
instructions determine whether or not status (i.e., 
the upper 4 bits of the PSW) is restored upon return 
from a subroutine. 

Input/Output Instructions 

Two 8-bit data bus buffer registers (DBBIN and 
DBBOUT) and an 8-bit status register (STS) enable 
the UPI-41A universal peripheral interface to com- 
municate with the external microcomputer system. 
Data can be INputted from the DBBIN register to 
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the accumulator. Data can be OUTputted from the 
accumulator to the DBBOUT register. 

The STS register contains four user-definable bits 
(ST4-ST7) plus four reserved status bits (IBF, OBF, 
Fo, and Fi). The user-definable bits are set from the 
accumulator. 

The UPI-41A peripheral interface has two 8-bit stat- 
ic I/O ports which can be loaded to and from the ac- 
cumulator. Outputs are statically latched but inputs 
to the ports are sampled at the time an IN instruc- 
tion is executed. In addition, immediate data from 
program memory can be ANDed and ORed directly 
to PORTS 1 and 2 with the result remaining on the 
port. This allows "masks" stored in program memory 
to be used to set or reset individual bits on the I/O 
ports. PORTS 1 and 2 are configured to allow input 
on a given pin by first writing a "1" to the pin. 

Four additional 4 -bit ports are available through the 
8243 I/O expander device. The 8243 interfaces to the 
UPI-41A peripheral interface via four PORT 2 lines 
which form an expander bus. The 8243 ports have 
their own AND and OR instructions like the on- 
board ports, as well as move instructions to transfer 
data in or out. The expander AND or OR instruc- 
tions, however, combine the contents of the accumu- 
lator with the selected port rather than with 
immediate data as is done with the on-board ports. 



Instruction Set Description 

The following section provides a detailed descrip- 
tion of each UPI instruction and illustrates how the 
instructions are used. 

For further information about programming the 
UPI, consult the 8048/8041A Assembly Language 
Manual 



Table 3-1. 


Symbols and Abbreviations Used 


Symbol 


Definition 


A 


Accumulator 


C 


Carry 


DBBIN 


Data Bus Buffer Input 


DBBOUT 


Data Bus Buffer Output 


Fo,Fi 


FLAG 0, FLAG 1 (C/D flag) 


I 


Interrupt 


P 


Mnemonic for "in-page" operation 


PC 


Program Counter 


Pp 


Port designator (p = 1, 2, or 4-7) 


PSW 


Program Status Word 


Rr 


Register designator (r = 0-7) 


SP 


Stack Pointer 


STS 


Status register 


T 


Timer 


TF 


Timer Flag 


To,Ti 


TEST 0, TEST 1 


# 


Immediate data prefix 


@ 


Indirect address prefix 


(()) 


Double parentheses show the effect of @, 




that is, (a)RO is shown as ((RO)). 





Contents of 



Table 3-2. Instruction Set Summary 



Mnemonic 


Operation Description 


Bytes 


Cycles 


Accumulator 








ADD A,Rr 


Add register to A 






ADD A,(a)Rr 


Add data memory to A 






ADD A,#data 


Add immediate to A 






ADDC A,Rr 


Add register to A with carry 






ADDC A,(5)Rr 


Add data memory to A with carry 






ADDC A,#data 


Add immediate to A with carry 






ANL A,Rr 


And register to A 






ANL A,@Rr 


And data memory to A 






ANL A,#data 


And immediate to A 






ORL A,Rr 


Or register to A 






ORL A,@Rr 


Or data memory to A 






ORL A,#data 


Or immediate to A 






XRL A,Rr 


Exclusive Or register to A 






XRL A,@Rr 


Exclusive Or data memory to A 






XRL A,#data 


Exclusive Or immediate to A 






INC A 


Increment A 






DEC A 


Decrement A 






CLR A 


Clear A 






CPL A 


Complement A 






DA A 


Decimal Adjust A 






SWAP A 


Swap nibbles of A 






RL A 


Rotate A left 






RLC A 


Rotate A left through carry 






RR A 


Rotate A right 






RRC A 


Rotate A right through carry 
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Table 3-2. Instruction Set Summary (Con't.) 



Mnemonic 


Operation Description 


Bytes 


Cycles 


INPUT/OUTPUT 

IN A,Pp 
OUTL Pp,A 
ANL Pp,#data 
ORL Pp,#data 
IN A,DBB 
OUT DBB,A 
MOV STS,A 
MOVD A,Pp 
MOVD Pp,A 
ANLD Pp,A 
ORLD Pp,A 


Input port to A 
Output A to port 
And immediate to port 
Or immediate to port 
Input DBB to A, clear IBF 
Output A to DBB, Set OBF 
A4-A7 to bits 4-7 of status 
Input Expander port to A 
Output A to Expander port 
And A to Expander port 
Or A to Expander port 




2 
2 
2 
2 
1 
1 
1 
2 
2 
2 
2 


DATA MOVES 
MOV A,Rr 
MOV A,@Rr 
MOV A,#data 
MOV Rr,A 
MOV (5)Rr,A 
MOV Rr,#data 
MOV @Rr,#data 
MOV A,PSW 
MOV PSW,A 
XCH A,Rr 
XCH A,@Rr 
XCHD A,@Rr 
MOVP A,@A 
M0VP3 A,@A 


Move register to A 
Move data memory to A 
Move immediate to A 
Move A to register 
Move A to data memory 
Move immediate to register 
Move immediate to data memory 
Move PSW to A 
Move A to PSW 
Exchange A and registers 
Exchange A and data memory 
Exchange digit of A and register 
Move to A from current page 
Move to A from Page 3 




1 
1 
2 
1 
1 
2 
2 
1 
1 
1 
1 
1 
2 
2 


TIMER/COUNTER 

MOV A,T 
MOV T,A 
STRT T 
STRT CNT 
STOP TCNT 
EN TCNTI 
DIS TCNTI 


Read Timer/Counter 

Load Timer/Counter 

Start Timer 

Start Counter 

Stop Timer/Counter 

Enable Timer/Counter Interrupt 

Disable Timer/Counter Interrupt 






CONTROL 

EN DMA 
EN I 
DIS I 
EN FLAGS 
SEL RBO 
SEL RBI 
NOP 


Enable DMA Handshake Lines 
Enable IBF interrupt 
Disable IBF interrupt 
Enable Master Interrupts 
Select register bank 
Select register bank 1 
No Operation 






REGISTERS 

INC Rr 
INC (a)Rr 
DEC Rr 


Increment register 
Increment data memory 
Decrement register 






SUBROUTINE 

CALL addr 

RET 

RETR 


Jump to subroutine 

Return 

Return and restore status 




2 
2 
2 


FLAGS 

CLRC 

CPLC 

CLRFO 

CPLFO 

CLRFl 

CPLFl 


Clear Carry 
Complement Carry 
Clear Flag 
Complement Flag 
Clear Fi Flag 
Complement Fi Flag 
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Table 3-2. Instruction Set Summary (Con't.) 



Mnemonic 


Operation Description 


Bytes 


Cycles 


BRANCH 








JMP addr 


Jump unconditional 


2 


2 


JMPP @A 


Jump indirect 


1 


2 


DJNZ Rr,addr 


Decrement register and jump on non-zero 


2 


2 


JC addr 


Jump on Carry =1 


2 


2 


JNC addr 


Jump on Carry =0 


2 


2 


JZ addr 


Jump on A Zero 


2 


2 


JNZ addr 


Jump on A not Zero 


2 


2 


JTO addr 


Jump on To=l 


2 


2 


JNTO addr 


Jump on To=0 


2 


2 


JTl addr 


Jump on Ti = l 


2 


2 


JNTl addr 


Jump on Ti=0 


2 


2 


JFO addr 


Jump on Fq Flag=l 


2 


2 


JFl addr 


Jump on Fi Flag=l 


2 


2 


JTF addr 


Jump on Timer Flag=l 


2 


2 


JNIBF addr 


Jump on IBF Flag=0 


2 


2 


JOBF addr 


Jump on OBF Flag =1 


2 


2 


JBb addr 


Jump on Accumulator Bit 


2 


2 



ALPHABETIC LISTING 



ADD A,Rr Add Register Contents to Accumulator 



Opcode: 



Example: 



1 1 



1 r2 ri ro 



The contents of register 'r' are added to the accumulator. Carry is affected. 
(A) -^ (A) + (Rr) r=0-7 

ADDREG: ADD A,R6 ;ADD REG 6 CONTENTS 

;T0 ACC 



ADD A,@Rr Add Data Memory Contents to Accumulator 



Opcode: 



Example: 



110 


r 



The contents of the standard data memory location addressed by register 'r' bits 0-5 are added to the 

accumulator. Carry is affected. 

(A) - (A) + ((Rr)) r=0-1 



ADDM: MOV RO,#47 
ADD A,@RO 



MOVE 47 DECIMAL TO REG 
ADD VALUE OF LOCATION 
47 TO ACC 



ADD A, # data Add Immediate Data to Accumulator 



Opcode: 






11 



d7 ^6 ds d4 



d3 d2 di do 



This is a 2-cycle instruction. The specified data is added to the accumulator. Carry is affected. 
(A) -^ (A) + data 
Example: ADDID: ADD A,#ADDER ;ADD VALUE OF SYMBOL 

; 'ADDER' TO ACC 
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INSTRUCTION SET 



ADDC A,Rr Add Carry and Register Contents to Accumulator 



Opcode: 



Example: 



111 


1 r2 ri ro 



The content of the carry bit is added to accumulator location 0. The contents of register 'r' are then added to 
the accumulator. Carry is affected. 
(A) -^ (A) + (Rr) + (C) r=0-7 

ADDRGC: ADDC A,R4 ;ADD CARRY AND REG 4 

ICONTENTS TO ACC 



ADDC A,@Rr Add Carry and Data Memory Contents to Accumulator 



Opcode: 



Example: 



1 1 1 r 



The content of the carry bit is added to accumulator location 0. Then the contents of the standard data 
memory location addressed by register 'r' bits 0-5 are added to the accumulator. Carry is affected. 
(A)-(A) + ((Rr)) + (C) r=0-1 



ADDMC:MOVR1,#40 
ADDC A,@R1 



MOV '40' DEC TO REG 1 

ADD CARRY AND LOCATION 40 

CONTENTS TO ACC 



ADDC A,#data Add Carry and Immediate Data to Accumulator 



Opcode: 



1 


11 



6j de d5 d4 



d3 d2 di do 



This is a 2-cycle instruction. The content of the carry bit is added to accumulator location 0. Then the 
specified data is added to the accumulator. Carry is affected. 
(A) -^ (A) + data + (C) 
Example: ADDC A, #255 ;ADD CARRY AND '225' DEC 

;T0 ACC 



ANL A,Rr Logical AND Accumulator With Register Mask 



Opcode: 



1 



1 r2 ri ro 



Data in the accumulator is logically ANDed with the mask contained in working register 'r'. 
(A) -^ (A) AND (Rr) r=0-7 

Example: ANDREG: ANL A,R3 ;'AND' ACC CONTENTS WITH MASK 

;MASK IN REG 3 



ANL A,@Rr Logical AND Accumulator With Memory Mask 



Opcode: 



10 1 


r 



Data in the accumulator is logically ANDed with the mask contained in the data memory location referenced 



by register Y, bits 0-5. 
(A) - (A) AND ((Rr)) 
Example: ANDDM: MOV RO,#OFFH 
ANL A,#OAFH 



r=0-1 

MOVE 'FF' HEX TO REG 
'AND' ACC CONTENTS WITH 
MASK IN LOCATION 63 
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INSTRUCTION SET 



ANL A, # data Logical AND Accumulator With Immediate Mask 



Opcode: 



10 1 


11 



6j de d5 64 



d3 d2 di do 



This is a 2-cycle instruction. Data in the accumulator is logically ANDed with an immediately-specified mask. 
(A) — (A) AND data 

'AND' ACC CONTENTS 

WITH MASK 10101111 

AND' ACC CONTENTS 

WITH VALUE OF EXP 

3+X/Y' 



Example: ANDID: ANL A.#OAFH 
ANL A,#3+X/Y 



ANL Pp,#data Logical AND Port 1-2 With Immediate Mask 



Opcode: 



10 1 



1 pi po 



CI7 de d5 d4 



d3 d2 di do 



This is a 2-cycle instruction. Data on port 'p' is logically ANDed with an immediately-specified mask. 
(Pp) ^ (Pp) AND data p= 1 -2 



Note: Bits 0-1 of the opcode are used to represent PORT 1 and PORT 2. If you are coding in binary rather than 

assembly language, the mapping is as follows: 



Bits pll 



1 
1 
Example: ANDP2: ANL P2,#OF0H 



pO 



1 



1 



Port 
X 

1 
2 
X 



AND' PORT 2 CONTENTS 
WITH MASK 'FO' HEX 
;(CLEAR P20-23) 



ANLD Pp,A Logical AND Port 4-7 With Accumulator Mask 



Opcode: 



10 1 



1 1 PI PO 



This is a 2-cycle Instruction. Data on port 'p' on the 8243 expander is logically ANDed with the digit mask 

contained in accumulator bits 0-3. 

(Pp) *- (Pp) AND (AO-3) p=4-7 



Note: 



The mapping of Port 'p' to opcode bits pi,po Is as follows: 
PI PO Port 



;'AND' PORT 4 CONTENTS 
IWITH ACC BITS 0-3 









4 





1 


6 


1 





6 


1 


1 


7 



Example: ANDP4: ANLD P4,A 
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INSTRUCTION SET 



CALL address Subroutine Call 



Opcode: 



ag as 1 



10 



aj ae as a4 



as a2 ai ao 



Example: 



This is a 2-cycle instruction. The program counter and PSW bits 4-7 are saved in the stack. The stacl< 
pointer (PSW bits 0-2) is updated. Program control is then passed to the location specified by 'address'. 

Execution continues at the instruction following the CALL upon return from the subroutine. 

((SP)) - (PC), (PSW4-7) 

(SP) — (SP) + 1 

(PC8-9) ^ (addrs-g) 

(PC0-7) ^ (addro-7) 

Add three groups of two numbers. Put subtotals in locations 50, 61 and total In location 52. 



MOV R0,#50 

BEGADD: MOV A,R1 

ADD A,R2 
CALL SUBTOT 
ADD A,R3 
ADD A,R4 
CALL SUBTOT 
ADD A,R5 
ADD A,R6 
CALL SUBTOT 



MOVE '60' DEC TO ADDRESS 

REGO 

MOVE CONTENTS OF REG 1 

TO ACC 

ADD REG 2 TO ACC 

CALL SUBROUTINE 'SUBTOT' 

ADD REG 3 TO ACC 

ADD REG 4 TO ACC 

CALL SUBROUTINE 'SUBTOT' 

ADD REG 5 TO ACC 

ADD REG 6 TO ACC 

CALL SUBROUTINE 'SUBTOT' 



SUBTOT: MOV @RO,A 



INCRO 
RET 



MOVE CONTENTS OF ACC TO 
LOCATION ADDRESSED BY 
REGO 

INCREMENT REG 
RETURN TO MAIN PROGRAM 



CLR A Clear Accumulator 



Opcode: 



10 



111 



The contents of the accumulator are cleared to zero. 
(A) *- OOH 



CLR C Clear Carry Bit 



Opcode: 



10 1 



1 1 1 



During normal program execution, the carry bit can be set to one by the ADD, ADDC, RLC, CPLC, RRC, and 

DAA instructions. This instruction resets the carry bit to zero. 

(C)-0 



CLR F1 Clear Flag 1 



Opcode: 



10 10 



1 1 



The F-| flag is cleared to zero. 
(Fi)-0 
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INSTRUCTION SET 



CLR FO Clear Flag 



Opcode: 



10 


10 1 



Flag is cleared to zero. 
(Fo) ^ 



CPL A Complement Accumulator 



Opcode: 



Example: 



11 



1 1 1 



The contents of the accumulator are complemented. This is strictly a one's complement. Each one is 
changed to zero and vice-versa. 
(A) ^ NOT (A) 

Assume accumulator contains 01101010. 

CPLA: CPL A ;ACC CONTENTS ARE COMPLE- 

;MENTED TO 10010101 



CPL C Complement Carry Bit 



10 10 


111 



Opcode: 

The setting of the carry bit is complemented; one is changed to zero, and zero is changed to one. 
(C) ^ NOT (C) 
Example: Set C to one; current setting is unknown. 

CT01 : CLR C ;C IS CLEARED TO ZERO 

CPL C ;C IS SET TO ONE 



CPL FO Complement Flag 



Opcode: 



10 1 



The setting of Flag is complemented; one is changed to zero, and zero is changed to one. 
Fo *- NOT (FO) 



CPL F1 Complement Flag 1 



Opcode: 



10 11 



The setting of the Fi Flag is complemented; one is changed to zero, and zero is changed to one. 
(Fi)-NOT(Fi) 
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INSTRUCTION SET 



DA A Decimal Adjust Accumulator 



10 1 


111 



opcode: 

The 8-bit accumulator value is adjusted to form two 4-bit Binary Coded Decimal (BCD) digits following the 
binary addition of BCD numbers. The carry bit C is affected. If the contents of bits 0-3 are greater than nine, 
or if AC is one, the accumulator is incremented by six. 

The four high-order bits are then checked. If bits 4-7 exceed nine, or if C is one, these bits are increased by 
six. If an overflow occurs, C is set to one; otherwise, it is cleared to zero. 
Example: Assume accumulator contains 9AH. 

DA A ; ACC ADJUSTED TO 1 H with C set 



c 


AC 


ACC 










9AH 


INITIAL CONTENTS 






06H 


ADD SIX TO LOW DIGIT 








A1H 








60H 


ADD SIX TO HIGH DIGIT 


1 





01H 


RESULT 



DEC A Decrement Accumulator 



Opcode: 



Example: 






111 



The contents of the accumulator are decremented by one. 

(A)-(A)-1 

Decrement contents of data memory location 63. 



MOV R0,#3FH 
MOVA,@R0 

DEC A 
MOV @RO,A 



MOVE •3F' HEX TO REG 

MOVE CONTENTS OF LOCATION 63 

TO ACC 

DECREMENT ACC 

MOVE CONTENTS OF ACC TO 

LOCATION 63 



DEC Rr Decrement Register 



Opcode: 



Example: 



110 


1 V2 ri ro 



The contents of working register Y are decremented by one. 

(Rr) — (Rr) - 1 r=0-7 

DECR1: DEC RI ;DECREMENT ADDRESS REG 1 



DIS I Disable IBF Interrupt 



Opcode: 



Note: 



10 10 1 



The input Buffer Full interrupt is disabled. The interrupt sequence is not initiated by WR and CS, however, 

an IBF interrupt request is latched and remains pending until an EN I (enable IBF interrupt) instruction is 

executed. 

The IBF flag is set and cleared independent of the IBF interrupt request so that handshaking protocol can 

continue normally. 
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INSTRUCTION SET 



DIS TCNTI Disable Tinner /Counter interrupt 



Opcode: 



11 



10 1 



The timer /counter interrupt is disabled. Any pending timer interrupt request is cleared. The interrupt i 
quence is not initiated by an overflow, but the timer flag is set and time accumulation continues. 



DJNZ Rr, address Decrement Register and Test 



Opcode: 



1110 



1 r2 r-j ro 



a? ae as a4 



as a2 ai ao 



Note: 



Example: 



This is a 2-cycle instruction. Register Y is decremented and tested for zero. If the register contains all zeros, 

program control falls through to the next instruction. If the register contents are not zero, control jumps to the 

specified address within the current page. 

(Rr) - (Rr) - 1 

If R 7^ 0, then; 

(PCo-7) ^ acldr 

A 10-bit address specification does not cause an error if the DJNZ instruction and the jump target are on the 

same page. If the DJNZ instruction begins in location 255 of a page, it will jump to a target address on the 

following page. Otherwise, it is limited to a jump within the current page. 

Increment values in data memory locations 50-54. 



MOV R0,#50 
MOV R3,#06 
INCRT: INC @R0 



INCRO 

DJNZ R3,INCRT 

NEXT 



MOVE '50' DEC TO ADDRESS 

REGO 

MOVE '5' DEC TO COUNTER 

REG 3 

INCREMENT CONTENTS OF 

LOCATION ADDRESSED BY 

REGO 

INCREMENT ADDRESS IN REG 

DECREMENT REG 3 JUMP TO 

MNCRT' IF REG 3 NONZERO 
'NEXT' ROUTINE EXECUTED 
IF R3 IS ZERO 



EN DMA Enable DMA Handsliake Lines 



Opcode: 



DMA handshaking is enabled using P26 as DMA request (DRQ) and P27 as DMA acknowledge (DACK). The 
DACK line forces CS and Aq low internally and clears DRQ. 



EN FLAGS Enable Master Interrupts 



Opcode: 



1111 


10 1 



The Output Buffer Full (OBF) and the Input Buffer Full (IBF) flags (IBF is inverted) are routed to P24 and P25. 
For proper operation, a " 1 " should be written to P25 and P24 before the EN FLAGS instruction. A "0" written 
to P24 or P26 disables the pin. 
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INSTRUCTION SET 



EN I Enable IBF Interrupt 



Opcode: 






10 1 



The Input Buffer Full interrupt is enabled. A low signal on WR and CS initiates the interrupt sequence. 



EN TCNTI Enable Tinner/Counter Interrupt 



Opcode: 



10 



10 1 



The timer /counter interrupt is enabled. An overflow of this register initiates the interrupt sequence. 



IN A,DBB Input Data Bus Buffer Contents to Accumulator 



Opcode: 



Example: 



10 


10 



Data in the DBBIN register is transferred to the accumulator and the Input Buffer Full (IBF) flag is set to zero. 
(A) - (DBB) 
(IBF) — 

INDBB: IN A.DBB ;INPUT DBBIN CONTENTS TO 

;ACCUMULATOR 



IN A,Pp Input Port 1-2 Data to Accumulator 



Opcode: 



Example: 






1 pi po 



This is a 2-cycle instruction. Data present on port 'p' is transferred (read) to the accumulator. 
(A) -^ (Pp) p= 1-2 (see ANL instruction) 

INP12: IN A,P1 ilNPUT PORT 1 CONTENTS 

;T0 ACC 
MOV R6,A ;MOVE ACC CONTENTS TO 

;REG6 
IN A,P2 ;INPUT PORT 2 CONTENTS 

;T0 ACC 
MOV R7,A ;MOVE ACC CONTENTS TO REG 7 



INC A Increment Accumulator 



Opcode: 



1 


111 



The contents of the accumulator are incremented by one. 
(A) - (A) + 1 



Example: Increment contents of location 10 in data memory. 

;MOV '10' DEC TO ADDRESS 

;REGO 

;MOVE CONTENTS OF LOCATION 

;10TOACC 



INCA: MOVR0,#10 
MOVA,@R0 



INCA 

MOV ©RO.A 



INCREMENT ACC 

MOVE ACC CONTENTS TO 

LOCATION 10 
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INSTRUCTION SET 



INC Rr Increment Register 



Opcode: 



1 


1 r2 ri ro 



The contents of working register V are incremented by one. 

(Rr) -^ (Rr) + 1 r=0-7 

INCRO: INC RO .INCREMENT ADDRESS REG 



Example 

INC @Rr Increment Data Memory Location 



Opcode: 



Example: 



1 r 



The contents of the resident data memory location addressed by register 'r' bits 0-5 are incremented by 

one. 

((Rr)) - ((Rr)) + 1 r=0-1 

INCDM: MOV R1,#0FFH ;MOVE ONES TO REG 1 

INC @R1 ;INCREMENT LOCATION 63 



JBb address Jump If Accumulator Bit is Set 



Opcode: 



b2 bi bo 1 



a? 36 ^5 M 



as a2 ai ao 



This is a 2-cycle instruction. Control passes to the specified address if accumulator bit 'b' Is set to one. 
(PCo-7)^addr if b=1 

(PC) -^ (PC) + 2 if b=0 

Example: JB4IS1: JB4 NEXT ;JUMP TO 'NEXT' ROUTINE 

;IF ACC BIT 4= 1 



JC address Jump If Carry Is Set 



Opcode: 



110 



a? ae as a4 



as a2 ai ao 



Example: 



This is a 2-cycle instruction. Control passes to the specified address If the carry bit is set to one. 
(PCo-7) -^ addr if C=1 

(PC) -*- (PC) + 2 if C=0 

JC1: JC OVERFLOW ;JUMP TO 'OVFLOW ROUTINE 

;IFC=1 



JFO address Jump If Flag Is Set 



Opcode: 



10 11 


110 



a? ae as a4 



as a2 ai ao 



This is a 2-cycle instruction. Control passes to the specified address if flag is set to one. 
(PCo-7)^addr ifFo=1 

Example: JF0IS1: JFO TOTAL ;JUMP TO 'TOTAL' ROUTINE 

;IFFo=1 
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INSTRUCTION SET 



JF1 address Jump If C/D Flag (F1) Is Set 



Opcode: 



111 



110 



a? 36 as 34 



a3 82 ai ao 



This is a 2-cycle instruction. Control passes to the specified address if the C/D flag (Fi) is set to one. 
(PCo-7)^addr ifFi = 1 

Example: JF 1IS1: JF1 FILBUF ;JUMP TO 'FILBUF' 

;R0UTINEIFFi = 1 



JMP address Direct Jump Within IK Block 



Opcode: 



aio ag as 



10 



aj ag as 34 



as a2 ai ao 



Example: 



This is a 2-cycle instruction. Bits 0-9 of the program counter are replaced with the directly-specified 

address. 

(PCs-9) -^ addr 8-9 

(PC0-7) -^ addr 0-7 



JMP SUBTOT 
JMP $-6 

JMP 2FH 



JUMP TO SUBROUTINE 'SUBTOT' 
JUMP TO INSTRUCTION SIX LOCATIONS 
BEFORE CURRENT LOCATION 
JUMP TO ADDRESS '2F' HEX 



JMPP @A Indirect Jump Within Page 



Opcode: 



Example: 



10 11 



11 



This is a 2-cycle instruction. The contents of the program memory location pointed to by the accumulator are 

substituted for the 'page' portion of the program counter (PC 0-7). 

(PC0-7) - ((A)) 

Assume accumulator contains OFH 

JMPPAG: JMPP @A ;JMP TO ADDRESS STORED IN 

;LOCATION 15 IN CURRENT PAGE 



JNC address Jump If Carry Is Not Set 



Opcode: 



1110 


110 



a7 as as a4 



as a2 ai ao 



This is a 2-cycle instruction. Control passes to the specified address if the carry bit is not set, that is, equals 
zero. 

(PC0-7) *- addr If C=0 

Example: JCO: JNC NOVFLO ;JUMP TO 'NOVFLO' ROUTINE 

;IF C=0 



JNIBF address Jump If Input Buffer Full Flag Is Low 



Opcode: 



110 1 



110 



a7 ae as a4 



as a2 a^ ao 



This is a 2-cycle instruction. Control passes to the specified address if the Input Buffer Full flag is low 
(IBF=0). 

(PC0-7) -^ addr if IBF=0 

Example: LOC 3:JNIBF LOC 3 ;JUMP TO SELF IF IBF=0 

;OTHERWISE CONTINUE 
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INSTRUCTION SET 



JNTO address Jump If TEST Is Low 



Opcode: 



10 


110 



a? ae as 34 



33 32 ai ao 



This is a 2-cycie instruction. Control passes to the specified address, if the TEST signal is low. Pin is 
sampled during SYNC. 
(PC0-7) ^ addr if To=0 

Example: JTOLOW: JNTO 60 ; JUMP TO LOCATION 60 DEC 

;IF To=0 



JNT1 address Jump If TEST 1 Is Low 



Opcode: 



1 1 1 • 37 ag as 34 33 32 ai ao 



This is 3 2-cycle instruction. Control pesses to the specified 3ddress if the TEST 1 signel is low. Pin is 
ssmpled during SYNC. 
(PC0-7) *- addr if Ti=0 

Example: JT1L0W: JNT1 OBBH ;JUMP TO LOCATION 'BB' HEX 

;IFTi=0 



JNZ address Jump If Accumulator Is Not Zero 



Opcode: 



1 1 1 1 • 37 36 as 34 33 32 31 30 



This is a 2-cycle instruction. Control passes to the specified address if the eccumulstor contents ere nonzero 
3t the time this instruction is executed. 
(PC0-7) — addr \i A^O 

Example: JACCNO: JNZ OABH ;JUMP TO LOCATION 'AB' HEX 

;IF ACC VALUE IS NONZERO 



JOBF Address Jump If Output Buffer Full Flag Is Set 



Opcode: 



10 


110 



37 36 3S 34 



33 32 31 30 



This is 3 2-cycle instruction. Control pesses to the specified eddress if the Output Buffer Full (OBF) fleg is set 
(= 1) 3t the time this instruction is executed. 
(PCo-7)^addr ifOBF=1 

Example: JOBFHI: JOBF OAAH ;JUMP TO LOCATION 'AA' HEX 

;IF0BF=1 



JTF address Jump If Timer Flag Is Set 



Opcode: 



1 


110 



a7 a6 as 34 



33 32 31 30 



Example: 



This is 3 2-cycle instruction. Control pesses to the specified eddress if the timer fleg is set to one, thet is, the 
timer /counter register overflows to zero. The timer fleg is cleered upon execution of this instruction. (This 
overflow initistes en interrupt service sequence if the timer-overflow interrupt is enebled.) 
(PCo-7)^addr ifTF=1 

JTF1: JTF TIMER ;JUMP TO TIMER' ROUTINE 

;IFTF=1 
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JTO address Jump If TEST Is High 



Opcode: 



11 


110 



a/ ae ^5 34 



as 32 ai ao 



This is a 2-cycle instruction. Control passes to the specified address if the TEST signal is high (= 1). Pin is 
sampled during SYNC. 
(PCo-7) -^ addr if To=1 

Example: JTOHI: JTO 63 ;JUMP TO LOCATION 63 DEC 

;IFTo=1 



JT1 address Jump If TEST 1 Is High 



Opcode: 



1 1 1 1 • 37 ae 35 34 33 32 ai ao 



This is a 2-cycle instruction. Control passes to the specified address if the TEST 1 signal is high (= 1). Pin is 
sampled during SYNC. 
(PC0-7) -»- addr if Ti = 1 

Example: JT1HI: JT1 COUNT ;JUMP TO 'COUNT' ROUTINE 

;IFTi = 1 



JZ address Jump If Accumulator Is Zero 



Opcode: 



110 



1 1 



37 as as 34 



33 32 31 30 



This is 3 2-cycle instruction. Control p3sses to the specified 3ddress if the 3ccumul3tor cont3ins 3li zeros 3t 
the time this instruction is executed. 
(PC0-7) -^ 3ddr if A=0 

Example: JACCO: JZ 0A3H ;JUMP TO LOCATION 'A3' HEX 

;IF ACC VALUE IS ZERO 



MOV A,#data Move Immediate Data to Accumulator 



Opcode: 



10 



11 



d7 de ds d4 



d3 d2 di do 



This is 3 2-cycle instruction. The 8-bit V3lue specified by 'd3t3' is lo3ded in the 3Ccumul3tor. 
(A) -*- d3t3 
Example: MOV A,#0A3H ;MOV 'A3' HEX TO ACC 



MOV A,PSW Move PSW Contents to Accumulator 



Opcode: 



Example: 



1 







111 



The contents of the progr3m st3tus word 3re moved to the 3CCumul3tor. 
(A) *- (PSW) 

Jump to 'RBI SET' routine if b3nk switch, PSW bit 4, is set. 
BSCHK: MOV A.PSW ;MOV PSW CONTENTS TO ACC 

JB4 RBI SET ;JUMP TO 'RBI SET' IF ACC 

;BIT4=1 
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MOV A, Rr Move Register Contents to Accumulator 



Opcode: 



Example: 



1111 



1 r2 ri ro 



Eight bits of data are moved from working register 'r' into the accumulator. 
(A) — (Rr) r=0-7 

MAR: MOV A,R3 ;MOVE CONTENTS OF REG 3 

;T0 ACQ 



MOV A,@Rr Move Data Memory Contents to Accumulator 



Opcode: 



Example: 



1111 


r 



The contents of the data memory location addressed by bits 0-5 of register 'r' are moved to the accumula- 
tor. Register V contents are unaffected. 
(A) — ((Rr)) r=0-1 

Assume RI contains 001 101 10. 



MADM: MOV A,@R1 



;MOVE CONTENTS OF DATA MEM 
;LOCATION 54 TO ACC 



MOV A,T Move Timer/ Counter Contents to Accumulator 



Opcode: 



Example: 



10 


10 



The contents of the timer /event-counter register are moved to the accumulator. The timer /event-counter is 

not stopped. 

(A) - (T) 

Jump to "EXIT" routine when timer reaches '64', that is, when bit 6 is set — assuming initialization to zero. 

TIMCHK: MOV A,T ;MOVE TIMER CONTENTS TO 

;ACC 
JB6 EXIT ;JUMP TO 'EXIT' IF ACC BIT 

;6=1 



MOV PSW,A Move Accumulator Contents to PSW 



Opcode: 



Example: 



1 



1 



111 



The contents of the accumulator are moved into the program status word. All condition bits and the stack 

pointer are affected by this move. 

(PSW) -»- (A) 

Move up stack pointer by two memory locations, that is, increment the pointer by one. 

INCPTR: MOV A,PSW ;MOVE PSW CONTENTS TO ACC 

INC A ;INCREMENT ACC BY ONE 

MOV PSW.A ;MOVE ACC CONTENTS TO PSW 
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MOV Rr,A Move Accumulator Contents to Register 



Opcode: 



Example: 



10 10 


1 r2 ri ro 



The contents of the accumulator are moved to register 'r'. 
(Rr) ^ (A) r=0-7 

MRA MOV RO,A ;MOVE CONTENTS OF ACC TO 

;REGO 



MOV Rr,#data Move Immediate Data to Register 



Opcode: 



10 11 



1 r2 ri ro 



d7 de d5 d4 



d3 d2 d-j do 



This a 2-cycle instruction. The 8-blt value specified by 'data' is moved to register V. 



(Rr) -*- data 
Example: MIR4: MOV R4,#HEXTEN 



MIR5: MOV R5;#PI*(R*R) 



MIR6: MOV R6,#0ADH 



r=0-7 

THE VALUE OF THE SYMBOL 
'HEXTEN' IS MOVED INTO 
REG 4 

THE VALUE OF THE 
EXPRESSION 'PI*(R*R)' 
IS MOVED INTO REG 5 
'AD' HEX IS MOVED INTO 
REG 6 



MOV @Rr,A Move Accumulator Contents to Data Memory 



10 10 


r 



Opcode: 

The contents of the accumulator are moved to the data memory location whose address is specified by bits 
0-6 of register 'r'. Register 'r' contents are unaffected. 
((Rr)) — (A) r=0-1 

Example: Assume RO contains 1 10001 1 1 . 

MDMA: MOV @R,A ;MOVE CONTENTS OF ACC TO 

;LOCATION 7 (REG) 



MOV @Rr,#data Move Immediate Data to Data Memory 



Opcode: 



10 11 


r 



d/ de d5 d4 



d3 d2 di do 



Example: 



This is a 2-cycle instruction. The 8-bit value specified by 'data' is moved to the standard data memory 

location addressed by register 'r', bit 0-6. 

((Rr)) — data r=0-1 

Move the hexadecimal value AC3F to locations 62-63. 



MIDM: MOVR0,#62 

MOV @RO,#OACH 

INCRO 

MOV @R0,#3FH 



MOVE '62' DEC TO ADDR REGO 
MOVE 'AC HEX TO LOCATION 62 
INCREMENT REG TO '63' 
MOVE '3F' HEX TO LOCATION 63 
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INSTRUCTION SET 



MOV STS.A Move Accumulator Contents to STS Register 



10 1 






Opcode: 

The contents of the accumulator are moved into the status register. Only bits 4-7 are affected. 

(STS4-7) ^ (A4-7) 
Example: Set ST4-ST7 to " 1 " . 



MSTS: MOV A,#OFOH 
MOV STS,A 



;SET AGO 
;MOVE TO STS 



MOV T,A Move Accumulator Contents to Timer/Counter 



Opcode: 



Example: 



110 


10 



The contents of the accumulator are moved to the timer /event-counter register. 

(T)-(A) 

Initialize and start event counter. 



INITEC: CLR A 

MOV T,A 
STRT CNT 



CLEAR ACC TO ZEROS 

MOVE ZEROS TO EVENT COUNTER 

START COUNTER 



MOVD A,Pp Move Port 4-7 Data to Accumulator 



Opcode: 



Note: 






1 1 PI PO 



This is a 2-cycle instruction. Data on 8243 port 'p' is moved (read) to accumulator bits 0-3. Accumulator bits 

4-7 are zeroed. 

(A0-3) ^ Pp p=4-7 

(A4-7) ^ 

Bits 0-1 of the opcode are used to represent PORTS 4-7. If you are coding in binary rather than assembly 

language, the mapping is as follows: 



Bits P1 PO 



1 

1 

1 1 



Example: INPPT5: MOVD A,P6 



Port 

4 
6 
6 

7 

IMOVE PORT 5 DATA TO ACC 
;BITS 0-3, ZERO ACC BITS 4-7 



MOVD Pp,A Move Accumulator Data to Port 4, 5, 6 and 7 



Opcode: 



Example: 



1 



1 1 PI PO 



This is a 2-cycle instruction. Data in accumulator bits 0-3 is moved (written) to 8243 port 'p'. Accumulator 
bits 4-7 are unaffected. (See NOTE above regarding port mapping.) 
(Pp) — (A0-3) P=4-7 

Move data in accumulator to ports 4 and 6. 



OUTP45: MOVD P4,A 
SWAP A 
MOVD P6,A 



MOVE ACC BITS 0-3 TO PORT 4 
EXCHANGE ACC BITS 0-3 AND 4-7 
MOVE ACC BITS 0-3 TO PORT 6 
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MOVP A,@A Move Current Page Data to Accumulator 



Opcode: 



Note: 



Example: 



10 10 



11 



This is a 2-cycle instruction. The contents of the program memory location addressed by the accumulator 

are moved to the accumulator. Only bits 0-7 of the program counter are affected, limiting the program 

memory reference to the current page. The program counter is restored following this operation. 

(A) - ((A)) 

This is a 1-byte, 2-cycle instruction. If it appears in location 256 of a program memory page, @ A addresses 

a location in the following page. 

MOVE '128' DEC TO AGO 

CONTENTS OF 129TH LOCATION 

IN CURRENT PAGE ARE MOVED TO 

ACC 



MOV 128: MOV A, #128 
MOVP A, @ A 



M0VP3 A,@A Move Page 3 Data to Accumulator 



Opcode: 



Example: 



1110 



11 



This is a 2-cycle instruction. The contents of the program memory location within page 3, addressed by the 
accumulator, are moved to the accumulator. The program counter is restored following this operation. 
(A) —- ((A)) within page 3 

Look up ASCII equivalent of hexadecimal code in table contained at the beginning of page 3. Note that ASCII 
characters are designated by a 7-bit code; the eighth bit is always reset. 



TABSCH: MOV A,#0B8H 
ANLA,#7FH 



MOVE '88' HEX TO ACC (101 1 1000) 
LOGICAL AND ACC TO MASK BIT 
7(00111000) 
M0VP3, A, @ A ;MOVE CONTENTS OF LOCATION 

'38' HEX IN PAGE 3 TO ACC 
(ASCII '8') 
Access contents of location in page 3 labelled TAB1. Assume current program location is not in page 3. 



TABSCH: MOV A,#TAB1 



M0VP3A,@A 



ISOLATE BITS 0-7 

OF LABEL 

ADDRESS VALUE 

MOVE CONTENT OF PAGE 3 

LOCATION LABELED 'TAB1' 

TO ACC 



NOP The NOP Instruction 



00000000 



Opcode: 

No operation is performed. Execution continues with the following instruction. 

ORL A,Rr Logical OR Accumulator With Register Mask 
Opcode: 



Example: 



10 


1 r2 ri ro 



Data in the accumulator is logically ORed with the mask contained in working register 'r'. 
(A) -^ (A) OR (Rr) r=0-7 

ORREG: ORL A,R4 ;'0R' ACC CONTENTS WITH 

;MASK IN REG 4 
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ORL A,@Rr Logical OR Accumulator With Memory Mask 



Opcode: 



Example: 



10 


r 



Data In the accumulator Is logically ORed with the mask contained in the data memory location referenced by 

register Y, bits 0-5. 

(A) — (A) OR ((Rr)) r=0-1 



ORDM: MOVE R0,#3FH 
ORL A,@RO 



MOVE '3F' HEX TO REG 

'OR' AGO GONTENTS WITH MASK 

IN LOGATION 63 



ORL A, # data Logical OR Accumulator With Immediate Mask 



Opcode: 



10 


11 



d7 de ds d4 



ds d2 di do 



Example: 



This is a 2-cycle instruction. Data in the accumulator Is logically ORed with an immediately-specified mask. 
(A) -*- (A) OR data 

GRID: ORL A,#'X' ;'0R' AGG GONTENTS WITH MASK 

;0 101 1000 (ASGII VALUE OF 'X') 



ORL Pp,#data Logical OR Port 1-2 With Immediate Mask 



Opcode: 



10 



1 pi po 



d7 de d5 d4 



d3 d2 di do 



This is a 2-cycle instruction. Data on port 'p' is logically ORed with an immediately-specified mask. 
(Pp) -*- (Pp) OR data p= 1-2 (see OUTL instruction) 



Example: ORP 1 : ORL P 1 , #OFFH 



'OR' PORT 1 GONTENTS WITH 
MASK 'FF' HEX (SET PORT 1 
TO ALL ONES) 



ORLD Pp,A Logical OR Port 4-7 With Accumulator Mask 



10 


1 1 PI PO 



Opcode: 

This is a 2-cycle instruction. Data on 8243 port 'p' Is logically ORed with the digit mask contained in accumu- 
lator bits 0-3, 

(Pp) (Pp) OR (A0-3) p=4-7 (See MOVD Instruction) 

Example: 0RP7: ORLD P7,A ;'0R' PORT 7 GONTENTS 

;WITH AGG BITS 0-3 



OUT DBB,A Output Accumulator Contents to Data Bus Buffer 






10 



Opcode: 

Contents of the accumulator are transferred to the Data Bus Buffer Output register and the Output Buffer Full 
(OBF) flag is set to one. 
(DBB) - (A) 
OBF*- 1 
Example: OUTDBB: OUT DBB,A ;OUTPUT THE GONTENTS OF 

;THE AGG TO DBBOUT 
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OUTL Pp,A Output Accumulator Data to Port 1 and 2 



Opcode: 



Note: 



11 



1 pi po 



This is a 2-cycle instruction. Data residing in the accumuiator is transferred (written) to port 'p' and latched. 
(Pp)-(A) P=1-2 

Bits 0-1 of the opcode are used to represent PORT 1 and PORT 2. If you are coding in binary rather than 
assembly language, the mapping is as follows: 



Bits 



Pi 





1 
1 



Example: OUTLP: MOV A,R7 
OUTL P2,A 
MOV A,R6 
OUTL PI, A 



pO 



1 



1 



Port 
X 

1 
2 
X 



MOVE REG 7 CONTENTS TO AGO 
OUTPUT AGO CONTENTS TO P0RT2 
MOVE REG 6 CONTENTS TO ACC 
OUTPUT ACC CONTENTS TO PORT 1 



RET Return Without PSW Restore 



Opcode: 



10 


11 



This is a 2-cycle instruction. The stack pointer (PSW bits 0-2) is decremented. The program counter is then 
restored from the stack. PSW bits 4-7 are not restored. 
(SP) ^ (SP) - 1 
(PC) - ((SP)) 



RETR Return With PSW Restore 



Opcode: 



10 1 



11 



This is a 2-cycle instruction. The stack pointer is decremented. The program counter and bits 4-7 of the 

PSW are then restored from the stack. Note that RETR should be used to return from an interrupt, but should 

not be used within the interrupt service routine as it signals the end of an interrupt routine. 

(SP) *- (SP) - 1 

(PC)-((SP)) 

(PSW4_7) - ((SP)) 



RL A Rotate Left Without Carry 



Opcode: 



Example: 



1 



1 



1 



1 



The contents of the accumulator are rotated left one bit. Bit 7 Is rotated into the bit position. 

(An-l-l)^(An) n=0-6 

(Ao) - (A7) 

Assume accumulator contains 101 10001. 

RLNC: RL A ;NEW ACC CONTENTS ARE 01 10001 1 
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INSTRUCTION SET 



RLC A Rotate Left Through Carry 



Opcode: 



Example: 



1111 


1 1 1 



The contents of the accumulator are rotated left one bit. Bit 7 replaces the carry bit; the carry bit is rotated 

into the bit position. 

(An+l)^(An) n=0-6 

(Ao)-(C) 

(C)-(A7) 

Assume accumulator contains a 'signed' number; isolate sign without changing value. 



RLTC: CLR C 
RLC A 

RR A 



CLEAR CARRY TO ZERO 
ROTATE ACC LEFT, SIGN 
BIT (7) IS PLACED IN CARRY 
ROTATE ACC RIGHT — VALUE 
(BITS 0-6) IS RESTORED, 
CARRY UNCHANGED, BIT 7 
IS ZERO 



RR A Rotate Right Without Carry 



Opcode: 



Example: 



111 


111 



The contents of the accumulator are rotated right one bit. Bit is rotated into the bit 7 position. 

(An)-^(An+i) n=0-6 

(A7) - (Ao) 

Assume accumulator contains 101 10001. 

RRNC: RRA ;NEW ACC CONTENTS ARE 1 101 1000 



RRC A Rotate Right Through Carry 



Opcode: 



Example: 



110 


111 



The contents of the accumulator are rotated right one bit. Bit replaces the carry bit; the carry bit is rotated 
into the bit 7 position. 
(An)-^(An+i) n=0-6 

(A7)-(C) 
(C) - (Ao) 

Assume carry is not set and accumulator contains 101 10001. 
RRTC: RRCA ;CARRY IS SET AND ACC 

;CONTAINS 0101 1000 



SEL RBO Select Register Bank 



Opcode: 



110 


10 1 



PSW BIT 4 is set to zero. References to working registers 0-7 address data memory locations 0-7. This Is 
the recommended setting for normal program execution. 
(BS) — 
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INSTRUCTION SET 



SEL RB1 Select Register Bank 1 



Opcode: 



Example: 



110 1 



10 1 



PSW bit 4 is set to one. References to worl<ing registers 0-7 address data memory locations 24-31 . Tliis is 

the recommended setting for interrupt service routines, since locations 0-7 are left intact. The setting of 

PSW bit 4 in effect at the time of an interrupt is restored by the RETR instruction when the interrupt service 

routine is completed. 

(BS) - 1 

Assume an IBF interrupt has occurred, control has passed to program memory location 3, and PSW bit 4 

was zero before the interrupt. 

L0C3: JMP INIT ;JUMP TO ROUTINE 'INIT' 



INIT: MOV R7,A 

SEL RBI 

MOV R7,#0FAH 



MOV ACC CONTENTS TO 

LOCATION 7 

SELECT REG BANK 1 

MOVE 'FA' HEX TO LOCATION 31 



SEL RBO 
MOV A,R7 
RETR 



SELECT REG BANK 

RESTORE ACC FROM LOCATION 7 

RETURN—RESTORE PC AND PSW 



STOP TCNT Stop Timer/Event Counter 



Opcode: 



Example: 



110 


10 1 



This instruction is used to stop both time accumulation and event counting. 

Disable interrupt, but jump to interrupt routine after eight overflows and stop timer. Count overflows in 

register 7. 

DISABLE TIMER INTERRUPT 

CLEAR ACC TO ZERO 

MOV ZERO TO TIMER 

MOVE ZERO TO REG 7 

START TIMER 

JUMP TO ROUTINE 'COUNT' 

IF TF=1 AND CLEAR TIMER FLAG 

CLOSE LOOP 

INCREMENT REG 7 

MOVE REG 7 CONTENTS TO ACC 

JUMP TO ROUTINE 'INT' IF ACC 

BIT 3 IS SET (REG 7=8) 

OTHERWISE RETURN TO ROUTINE 

MAIN 



START: DIS TCNTI 
CLRA 
MOV T,A 
MOV R7,A 
STRTT 

MAIN: JTF COUNT 

JMP MAIN 
COUNT: INC R7 

MOV A,R7 
JB3 INT 

JMP MAIN 



INT: STOP TCNT 
JMP7H 



STOP TIMER 

JUMP TO LOCATION 7 (TIMER 

INTERRUPT ROUTINE) 
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INSTRUCTION SET 



STRT CNT Start Event Counter 



Opcode: 



Example: 



10 


10 1 



The TEST 1 (T-j) pin is enabled as the event-counter input and the counter is started. The event-counter 

register is incremented with each high to low transition on the Ti pin. 

Initialize and start event counter. Assume overflow is desired with first Ti input. 

STARTC: EN TCNTI ;ENABLE COUNTER INTERRUPT 

MOV A,#OFFH ;MOVE 'FF' HEX (ONES) TO 

;ACC 

MOV T,A ;MOVE ONES TO COUNTER 

STRT CNT ;INPUT AND START 



STRTT Start Timer 



Opcode: 



Example: 



10 1 



10 1 



Timer accumulation is initiated in the timer register. The register is incremented every 32 instruction cycles. 
The prescaler which counts the 32 cycles is cleared but the timer register is not. 
Initialize and start timer. 



STARTT: EN TCNTI 
CLRA 
MOV T,A 
STRTT 



ENABLE TIMER INTERRUPT 
CLEAR ACC TO ZEROS 
MOVE ZEROS TO TIMER 
START TIMER 



SWAP A Swap Nibbles Within Accumulator 



Opcode: 



Example: 



10 111 



Bits 0-3 of the accumulator are swapped with bits 4-7 of the accumulator. 

(A4-7) -•— ^ (A0-3) 

into location 50. 

;MOVE '60' DEC TO REG 

;M0VE'61'DECT0REG 1 

;EXCHANGE BIT 0-3 OF ACC 

;AND LOCATION 50 

;SWAP BITS 0-3 AND 4-7 OF ACC 

;EXCHANGE BITS 0-3 OF ACC AND 

;LOCATION 51 

;MOVE CONTENTS OF ACC TO 

;LOCATION 51 



Pack bits 0-3 of locations 50-51 
PCKDIG: MOV R0,#50 

M0VR1,#51 

XCHD A,@RO 

SWAP A 
XCHD A,@R1 

MOV @RO,A 



XCH A,Rr Exchange Accumulator-Register Contents 



Opcode: 



Example: 



1 



1 r2 ri ro 



The contents of the accumulator and the contents of working register Y are exchanged. 

(A) — ^ (Rr) r=0-7 

Move PSW contents to Reg 7 without losing accumulator contents. 



XCHAR7: XCH A,R7 

MOV A.PSW 
XCH A,R7 



EXCHANGE CONTENTS OF REG 7 
AND ACC 

MOVE PSW CONTENTS TO ACC 
EXCHANGE CONTENTS OF REG 7 
AND ACC AGAIN 
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INSTRUCTION SET 



XCH A,@Rr Exchange Accumulator and Data Memory Contents 



Opcode: 



Example: 



1 r 



The contents of the accumulator and the contents of the data memory location addressed by bits 0-6 of 
register 'r' are exchanged. Register 'r' contents are unaffected. 
(A)^— ((Rr)) r=0-1 

Decrement contents of location 52. 

;MOVE '62' DEC TO ADDRESS 

;REGO 

;EXCHANGE CONTENTS OF ACC 

;AND LOCATION 52 

.DECREMENT ACC CONTENTS 

;EXCHANGE CONTENTS OF ACC 

;AND LOCATION 52 AGAIN 



DEC52: MOV R0,#62 

XCH A,@RO 

DEC A 
XCH A,@RO 



XCHD A,@Rr Exchange Accumulator and Data Memory 4-bit Data 



Opcode: 



Example: 



11 


r 



This instruction exchanges bits 0-3 of the accumulator with bits 0-3 of the data memory location addressed 

by bits 0-6 of register 'r'. Bits 4-7 of the accumulator, bits 4-7 of the data memory location, and the 

contents of register 'r' are unaffected. 

(Ao-3) --^ ((Rro-3)) r=0-1 

Assume program counter contents have been stacked in locations 22-23. 



XCHNIB: MOV R0,#23 
CLRA 
XCHD A,@RO 



MOVE '23' DEC TO REG 
CLEAR ACC TO ZEROS 
EXCHANGE BITS 0-3 OF ACC 
AND LOCATION 23 (BITS 8-1 1 
OF PC ARE ZEROED, ADDRESS 
REFERS TO PAGE 0) 



XRL A,Rr Logical XOR Accumulator With Register Mask 



Opcode: 



Example: 



1 



1 



1 r2 ri ro 



Data in the accumulator is EXCLUSIVE ORed with the mask contained in working register 'r'. 
(A) -*- (A) XOR (Rr) r=0-7 

XORREG: XRL A,R6 ;'XOR' ACC CONTENTS WITH 

;MASK IN REG 6 



XRL A,@Rr Logical XOR Accumulator With Memory Mask 



Opcode: 



Example: 



110 1 


r 



Data in the accumulator is EXCLUSIVE ORed with the mask contained in the data memory location ad- 
dressed by register 'r', bits 0-5. 

r=0-1 

;MOVE '20' HEX TO REG 1 

;'XOR' ACC CONTENTS WITH MASK 

;IN LOCATION 32 



(A) - (A) XOR ((Rr)) 
XORDM:MOVR1,#20H 
XRLA,@R1 
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INSTRUCTION SET 



XRL A, # data Logical XOR Accumulator With Immediate Mask 



Opcode: 



110 1 



11 



d7 de d5 64 



d3 62 di do 



This is a 2-cycle instruction. Data in the accumulator is EXCLUSIVE ORed with an immediately-specified 

mask. 

(A) ♦- (A) XOR data 



Example: XORID: XOR A,#HEXTEN 



XOR CONTENTS OF ACC WITH 
MASK EQUAL VALUE OF SYMBOL 
HEXTEN' 
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CHAPTER 4 

SINGLE-STEP, PROGRAMMING, 

AND POWER-DOWN MODES 



SINGLE-STEP (8741A EPROM Only) 

The 8741A has a single-step mode which allows the 
user to manually step through his program one in- 
struction at a time. While stopped, the address of 
the next instruction to be fetched is available on 
PORT 1 and the lower 2 bits of PORT 2. The single- 
step feature simplifies program debugging by allow- 
ing the user to easily follow program execution. 



Figure 4-1 illustrates a recommended circuit for sin- 
gle-step operation, while Figure 4-2 shows the tim- 
ing relationship between the SYNC output and the 
SS input. During single -step operation, PORT 1 and 
part of PORT 2 are used to output address informa- 
tion. In order to retain the normal I/O functions of 
PORTS 1 and 2, a separate latch can be used as 
shown in Figure 4-3. 



MOMENTARY 
PUSH TO STEP 



CLEAR 




r 



y^ 



]> CLOCK 



TOSS 
-^ INPUT 

ON 8741 A 



-<h 



FROM 
8741 A 
SYNC 
OUTPUT 



Figure 4- 1 . Single-Step Circuit 
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Figure 4-2. Singie-Step Timing 
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P10 

P11 

P12 
P13 
P14 
P15 
P16 
P17 



-ix- 




^-(B- 



OC = OPEN COLLECTOR TTL 

LS = LOW POWER SCHOTTKLY TTL 



^ P17 INPUT DATA 



Figure 4-3. Latching Port Data 



Timing 

The sequence of single -step operation is as follows: 

1 ) The processorjs requested to stop by applying a 
low level on SS. The SS input should not be 
brought low_while SYNC is high. (The 8741 A 
samples the SS pin in the middle of the SYNC 
pulse). 

2) The processor responds to the request by stop- 
ping during the instruction fetch portion of the 
next instruction. If a double cycle instruction is 
in progress when the single-step command is re- 
ceived, both cycles will be completed before 
stopping. 

3) The processor acknowledges it has entered the 
stopped state by raising SYNC high. In this 
state, which can be maintained indefinitely, the 
10-bit address of the next instruction to be 
fetched is present on PORT 1 and the lower 2 
bits of PORT 2. 

4) SS is then raised high to bring the processor out 
of the stopped mode allowing it to fetch the 
next instruction. The exit from stop is indicated 
by the processor bringing SYNC low. 



5) To stop the processor at the next instruction SS 
must be brought low again before the next 
SYNC pulse — the circuit in Figure 4-1 uses the 
trailing edge of the previous pulse. If SS is left 
high, the processor remains in the "RUN" 
mode. 



Figure 4-1 shows a schematic for implementing sin- 
gle-step. A single D-type flip-flop with preset and 
clear is used to generate SS. In the RUN mode SS is 
held high by keeping the flip-flop preset (preset has 
precedence over the clear input). To enter single - 
step, preset is removed allowing SYNC to bring SS 
low via the clear input. Note that SYNC must be 
buffered since the SN7474 is equivalent to 3 TTL 
loads. 

The processor is now in the stopped state. The next 
instruction is initiated by clocking "1" into the flip- 
flop. This "1" will not appear on SS unless SYNC is 
high (i.e., clear must be removed from the flip-flop). 
In response to SS going high, the processor_begins an 
instruction fetch which brings SYNC low. SS is then 
reset through the clear input and the processor again 
enters the stopped state. 
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PROGRAMMING, VERIFYING AND 
ERASING EPROM (8741 A EPROM ONLY) 

The internal Program Memory of the 8741 A may be 
erased and reprogrammed by the user as explained 
in the following sections. See the data sheet for more 
detail. 

Programming 

The programming procedure consists of the follow- 
ing: activating the program mode, applying an 
address, latching the address, applying data, and 
applying a programming pulse. Each word is pro- 
grammed completely before moving on to the next 
and is followed by a verification step. Figure 4-4 
illustrates the programming and verifying sequence. 
The following is a list of the pins used for program- 
ming and a description of their functions: 
• XTAL 1, Clock Input (1 to 6 MHz) 
XTAL2 



• RESET Initialization and Address Latching 

• TEST Selection of Program or Verify 

Mode 

• EA Activation of Program/Verify 

Modes 

• D0-D7 Address and Data Input 

Data Output During Verify 



• P20> P2I Address Input 

• Vdd Programming Power Supply 

• PROG Program Pulse Input 

NOTE: All set-up and hold times are 4 cycles. 

The detailed ProgramA^erify sequence is as follows: 

1) VdD = 5V; Clo ck Runn ing 4MHz. Crystal or 
External Clock; RESET = OV; VdD = 5V; Aq 
= OV; CS = 5V 

TEST = 5V; EA = 5V, D0-D7 and PROG 
floating. 

2) Insert 8741A in programming socket. 

3) TEST = OV (Select Program Mode) 

4) EA = 23V (Activate Program Mode), PROG 
will float. 

5) Address appUed to D0-D7, P20> P21- 



6) RESET = 5V (Latch Address). 

7) Data appHed to D0-D7. 

8) Vdd = 25V (Programming Power). 



+23V 

+5V 



+25V 
+5V 

+5V 
+0V 



-BUS AND PROG CAN BE DRIVEN ONLY DURING THIS TIME - 



ADDRESS 0-7 



X 



3 — c 



ADDRESS AO' 



'-'' y 



L_. 



Figure 4-4. Programming Sequence 
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9) PROG = OV followed by 50ms pulse to 23V. 

10) VdD = 5V. 

11) TEST = 5V (Verify Mode). 

12) Read and Verify Data on D0-D7. 

13) TEST = OV. 



14) RESET = OV and repeat from step 5. 

15) Programmer should be at conditions of step 1 
when 8741A is removed from socket. 

WARNING 

An attempt to program a mis-socketed 8741A 
will result in severe damage to the part. An in- 
dication of a properly socketed part is the ap- 
pearance of the SYNC clock output. The lack 
of this clock may be used to disable the pro- 
grammer. 

Verification 

Verification is accomplished by latching in an ad- 
dress as in the Programming Mode and then apply- 
ing "1" to the TEST input. The word stored at the 
selected address then appears on the D0-D7 lines. 
Note that verification can be applied to both ROM's 
and EPROM's independently of the programming 
procedure. See the data sheet. 

Erasing 

The program memory of the 8741 A may be erased to 
zeros by exposing its translucent lid to shortwave ul- 
traviolet light. 

EPROM Light Sensitivity 

The erasure characteristics of the 8741A EPROM 
are such that erasure begins to occur when exposed 
to light with wavelengths shorter than approximate- 
ly 4000 Angstroms. It should be noted that sunlight 
and certain types of fluorescent lamps have wave- 
lengths in the 3000-4000 Angstrom range. Data 
shows that constant exposure to room level fluores- 
cent lighting could erase the typical 8741A in ap- 
proximately 3 years while it would take 
approximately 1 week to cause erasure when ex- 
posed to direct sunlight. If the 8741A is to be ex- 
posed to these types of lighting conditions for 
extended periods of time, opaque labels (available 
from Intel) should be placed over the 8741A window 
to prevent unintentional erasure. 

The recommended erasure procedure for the 8741A 
is exposure to shortwave ultraviolet light which has a 



wavelength of 2537 Angstroms. The integrated dose 
(i.e., UV intensity X exposure time) for erasure 
should be a minimum of 15W-sec/cm2 power rating. 
The erasure time with this dosage is approximately 
15 minutes using an ultraviolet lamp with a 12,000 
fiW/cnfi power rating. The 8741A should be placed 
within 1 inch of the lamp tubes during erasure. Some 
lamps have a filter on their tubes which should be 
removed before erasure. 

External Access 

The 8041A/8741A has an External Access (EA) pin 
which will put the processor into a test mode when a 
high level is applied. This allows the user to effec- 
tively disable the internal program memory. 

The External Access mode is useful in testing be- 
cause it allows the user to disable the internal appli- 
cation program and test processor functions 
directly. In addition, program memory can be read 
externally, independent of the processor. 

This mode is invoked by connecting the EA pin to 
5V. The current program counter contents then 
come out on PORTS 10-17 and PORTS 20-21 
(PORT 10 is the least significant and PORT 21 the 
most significant bits). The desired instruction 
opcode is placed on D0-D7. This instruction is exe- 
cuted in place of the internal program memory con- 
tents. The I/O port data and program address are 
multiplexed on the 8741A but not on the 8041A. 

Upon reset with EA = 5V, the 8041A sends out pro- 
gram counter contents OFFH as the first address 
rather than OOOH. The second address is OOIH. 
Therefore, the first and second instructions should 
be located at OFFH and OOIH respectively. The 
8741A outputs OOOH as the first address after reset. 

Reading and/or writing the Data Bus Buffer regis- 
ters is still allowed although only when D0-D7 are 
not being sampled for opcode data. In practice, since 
this sampling time is not known externally, reads or 
writes on the system bus are done during SYNC high 
time. Approximately 600ns are available for each 
read or write cycle. 

POWER DOWN MODE (8041 A ROM ONLY) 

Extra circuitry is included in the 8041A ROM ver- 
sion to allow low power, standby operation. Power is 
removed from all system elements except the 64- 
byte data RAM in the low power mode. Thus, the 
contents of RAM can be maintained while typically 
drawing only 10 to 15 % of normal power. 

The VcC piJ^ serves as the 5V supply pin for most of 
the 8041A circuitry while the VdD pi^^ supplies only 
the RAM array. In normal operation, both pins are 
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at 5 volts. To enter the Power-Down mode, the VCC 
pin is grounded while onl y VdD is maintained at 5 
volts. Applying a RESET signal to the processor in- 
hibits access to RAM and thereby guarantees that 
the memory is not inadvertently altered during the 
transition when power is removed from VqC- Figure 
4-5 illustrates a recommended Power-Down se- 
quence. The sequence typically occurs as follows: 



for instance) and call a Power Failure service 
routine. 

3) The Power Failure routine saves all important 
data and machine status in the RAM array. The 
routine may also initiate transfer of a backup 
supply to the VdD pin and indicate to external 
circuitry that the Power Failure routine is com- 
plete. 



1) Imminent power supply failure is detected by 
user defined circuitry. The signal must occur 
early enough to guarantee the 8041A can save 
all necessary data before VqC falls outside nor- 
mal operating tolerance. 



2) A "Power Failure" signal is used to interrupt 
the processor (via a timer overflow interrupt, 



4) A RESET signal is applied by external hard- 
ware to guarantee data will not be altered as the 
power supply falls out of limits. RESET must 
be low until VcC reaches ground potential. 

Recovery from the Power-Down mode can occur as 
any other pow er-on seq uence. An external 1 /ifd ca- 
pacitor on the RESET input will provide the neces- 
sary initialization pulse. 
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Figure 4-5. Power-Down Sequence 
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CHAPTER 5 
SYSTEM OPERATION 



BUS INTERFACE 

The UPI-41A Microcomputer functions as a periph- 
eral to a master processor by using the data bus 
buffer registers to handle data transfers. The DBB 
configuration is illustrated in Figure 5-1. The UPI- 
41A Microcomputer's 8 three-state data lines (D7- 
Dq) connect directly to the master processor's data 
bus. Data transfer to the master is controlled by 4 
external inputs to the UPI; 

• Aq Address Input signifying command 
or data 

• CS^ Chip Select 

• RD Read strobe 

• WR Write strobe 
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Figure 5-1. Data Bus Register Configuration 

The master processor addresses the UPI-41A Micro- 
computer as a standard peripheral device. Table 5-1 
shows the conditions for data transfer: 

Table 5-1. Data Transfer Controls 



cs 


AO 


ro 


WR 


Condition 











1 


Read DBBOUT 





1 





1 


Read STATUS 








1 





Write DBBIN data, set Fi = 





1 


1 





Write DBBIN command set 
Fi = l 


1 


X 


X 


X 


Disable DBB 



Reading the DBBOUT Register 

The sequence for reading the DBBOUT register is 
shown in Figure 5-2. This operation causes the 8-bit 
contents of the DBBOUT register to be placed on 



the system Data Bus. The OBF flag is cleared auto- 
matically. 

Reading STATUS 

The sequence for reading the UPI-41A Microcom- 
puter's 8 STATUS bits is shown in Figure 5-3. This 
operation causes the 8-bit STATUS register con- 
tents to be placed on the system Data Bus as shown. 

Write Data to DBBIN 

The sequence for writing data to the DBBIN register 
is shown in Figure 5-4. This operation causes the sys- 
tem Data Bus contents to be transferred to the 
DBBIN register and the IBF flag is set. Also, the Fi 
flag is cleared (Fi = 0) and an interrupt request is 
generated. When the IBF interrupt is enabled, a 
jump to location 3 will occur. The interrupt request 
is cleared upon entering the IBF service routine or 
by a system RESET input. 
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Figure 5-2. DBBOUT Read 
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Figure 5-3. Status Read 
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Figure 5-4. Writing Data to DBBIN 



Figure 5-5. Writing Commands to DBBIN 



Writing Commands to DBBIN 

The sequence for writing commands to the DBBIN 
register is shown in Figure 5-5. This sequence is 
identical to a data write except that the Aq input is 
latched in the Fi flag (Fi = 1). The IBF flag is set 
and an interrupt request is generated when the mas- 
ter writes a command to DBB. 

OPERATiONS OF DATA BUS REGISTERS 

The UPI-41A Microcomputer controls the transfer 
of DBB data to its accumulator by executing INput 
and OUTput instructions. An IN A,DBB instruction 
causes the contents to be transferred to the UPI ac- 
cumulator and the IBF flag is cleared. 

The OUT DBB, A instruction causes the contents of 
the accumulator to be transferred to the DBB OUT 
register. The OBF flag is set. 

The UPFs data bus buffer interface is applicable to a 
variety of microprocessors including the 8086, 8088, 
8085, 8080, and 8048. 

A description of the interface to each of these pro- 
cessors follows. 

DESIGN EXAMPLES 

8085A Interface 

Figure 5-6 illustrates an 8085A system using a UPI- 
41A. The 8085A system uses a multiplexed address 
and data bus. During I/O the 8 upper address lines 
(A8-A15) contain the same I/O address as the lower 
8 address/data lines (A0-A7); therefore I/O address 
decoding is done using only the upper 8 lines to 
eliminate latching of the address. An 8205 decoder 
provides address decoding for both the UPI-41A and 
the 8237. Data is transferred using the two DMA 



handshaking lines of PORT 2. The 8237 performs 
the actual bus transfer operation. Using the UPI- 
41A's OBF master interrupt, the UPI-41A notifies 
the 8085A upon transfe r com pletion using the RST 
5.5 interrupt input. The IBF master interrupt is not 
used in this example. 

8088 Interface 

Figure 5-7 illustrates a UPI-41A interface to an 8088 
minimum mode system. Two 8-bit latches are used 
to demultiplex the address and data bus. The ad- 
dress bus is 20-lines wide. For I/O only, the lower 16 
address lines are used, providing an addressing 
range of 64K. UPI address selection is accomplished 
using an 8205 decoder. The Aq address line of the 
bus is connected to the corresponding UPI input for 
register selection. Since the UPI-41A is polled by the 
8088, neither DMA nor master interrupt capabilities 
of the UPI-41A are used in the figure. 

8086 Interface 

The UPI-41A can be used on an 8086 maximum 
mode system as shown in figure 5-8. The address and 
data bus is demultiplexed using three 8282 latches 
providing separate address and data buses. The ad- 
dress bus is 20-lines wide and the data bus is 16-lines 
wide. Multiplexed control lines are decoded by the 
8288. The UPFs CS input is provided by linear selec- 
tion. Note that the UPI-41A is both I/O mapped and 
memory mapped as a result of the linear addressing 
technique. An address decoder may be used to limit 
the UPI-41A to a specific I/O mapped address. Ad- 
dress line Ai is connected to the UPFs Aq input. 
This insures that the registers of the UPI will have 
even I/O addresses. Data will be transferred on Dq- 
D7 lines only. This allows the I/O registers to be ac- 
cessed using byte manipulation instructions. 
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Figure 5-7. 8041 A To 8088 Minimum Mode System 
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Figure 5-8. 8041 A To 8086 Maximum Mode Systems 



8080 Interface 

Figure 5-9 illustrates the interface to an 8080A sys- 
tem. In this example, a crystal and capacitor are 
used for UPI-41A timing reference and power-on 
RESET. If the 2-MHz 8080A 2-phase clock were 
used instead of the crystal, the UPI-41A would run 
at only 30% full speed. 

The Aq and CS inputs are direct connections to the 
8080 address bus. In larger systems, however, either 
of these inputs may be decoded from the 16 address 
lines. 



The 8048 RD and WR outputs are directly compati- 
ble with the UPI. Figure 5-11 shows a distributed 
processing system with up to seven 8041A's con- 
nected to a single 8048 master processor. 



In this configuration the 8048 uses PORT as a data 
bus. I/O PORT 2 is used to select one of the seven 
8041A's when data transfer occurs. The 8041A's are 
programmed to handle isolated tasks and, since they 
operate in parallel, system throughput is increased. 



The RD and W R inp uts to th e U PI can be either the 
lOR and lOW or the MEMR and MEMR signals de- 
pending on the I/O mapping technique to be used. 

The UPI can be addressed as an I/O device using IN- 
put and OUTput instructions in 8080 software. 



8048 Interface 

Figure 5-10 shows the UPI interface to an 8048 mas- 
ter processor. 



GENERAL HANDSHAKING PROTOCOL 

1) Master reads STATUS register (RD, CS, Aq = 
(0, , 1)) in polling or in response to either an 
IBF or an OBF interrupt. 



2) If the UPI-41A DBBIN register is empty (IBF 
flag = 0) , Ma ster writes a word to the DBBIN 
register (WR, CS, Aq = (0, 0, 1) or (0, 0, 0)). If 
Aq = 1, write command word, set Fi. If Aq = 0, 
write data word, Fi = 0. 
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Figure 5- 1 0. 8048-804 1 A interface 



3) If the UPI-41A DBBOUT register is full (OBF 
flag = 1), Master reads a word from the 
DBBOUT register (RD, CS, Aq = (0, 0, 0)). 

4) UPI-41A recognizes IBF (via IBf" interrupt or 
JNIBF). Input data or command word is 
processed, depending on Fi; IBF is reset. Re- 
peat step 1 above. 



5) UPI-41A recognizes OBF flag = (via JOBF). 
Next word is output to DBBOUT register, OBF 
is set. Repeat step 1 above. 
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ABSTRACTS 

The UPI-41A is designed to fill a wide variety of low 
to medium speed peripheral interface applications 
where flexibility and easy implementation are im- 
portant considerations. The following examples il- 
lustrate some typical applications. 

Keyboard Encoder 

Figure 6-1 illustrates a keyboard encoder config- 
uration using the UPI and the 8243 I/O expander 
to scan a 128-key matrix. The encoder has switch 
matrix scanning logic, N-key rollover logic, ROM 
look-up table, FIFO character buffer, and additional 
outputs for display functions, control keys or other 
special functions. 

PORT 1 and PORTs 4-7 provide the interface to the 
keyboard. PORT 1 lines are set one at a time to se- 
lect the various key matrix rows. 

When a row is energized, all 16 columns (i.e., PORTs 
4-7 inputs) are sampled to determine if any switch 
in the row is closed. The scanning software is code 
efficient because the UPI instruction set includes in- 
dividual bit set/clear operations and expander 
PORTs 4-7 can be directly addressed with single, 2- 
byte instructions. Also, accumulator bits can be test- 
ed in a single operation. Scan time for 128 keys is 
about 10 ms. Each matrix point has a unique binary 



code which is used to address ROM when a key clo- 
sure is detected. Page 3 of ROM contains a look-up 
table with useable codes (i.e., ASCII, EBCDIC, etc.) 
which correspond to each key. When a valid key clo- 
sure is detected the ROM code corresponding to that 
key is stored in a FIFO buffer in data memory for 
transfer to the master processor. To avoid stray 
noise and switch bounce, a key closure must be de- 
tected on two consecutive scans before it is consid- 
ered vaUd and loaded into the FIFO buffer. The 
FIFO buffer allows multiple keys to be processed as 
they are depressed without regard to when they are 
released, a condition known as N-key rollover. 

The basic features of this encoder are fairly standard 
and require only about 500 bytes of memory. Since 
the UPI is programmable and has additional mem- 
ory capacity it can handle a number of other func- 
tions. For example, special keys can be programmed 
to give an entry on closing as well as opening. Also, 
I/O lines are available to control a 16-digit, 7 -seg- 
ment display. The UPI can also be programmed to 
recognize special combinations of characters such as 
commands, then transfer only the decoded informa- 
tion to the master processor. 

A complete keyboard application has been devel- 
oped for the UPI-41A. A description is included in 
this section. The code for the application is available 
in the Intel Insite Library (program AB 147). 
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Figure 6-1. Keyboard Encoder Configuration 
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Matrix Printer Interface 

The matrix printer interface illustrated in Figure 6-2 
is a typical application for the UPI-41A. The actual 
printer mechanism could be any of the numerous 
dot-matrix types and similar configurations can be 
shown for drum, spherical head, daisy wheel or chain 
type printers. 

The bus structure shown represents a generalized, 8- 
bit system bus configuration. The UPI's three-state 
interface port and asynchronous data buffer regis- 
ters allow it to connect directly to this type of system 
for efficient, two-way data transfer. 

The UPFs two on-board I/O ports provide up to 16 
input and output signals to control the printer 
mechanism. The timer/event counter is used for 
generating a timing sequence to control print head 
position, line feed, carriage return, and other se- 
quences. The on-board program memory provides 
character generation for 5 X 7, 7 X 9, or other dot 
matrix formats. As an added feature a portion of the 
64 X 8-bit data memory can be used as a FIFO buffer 
so that the master processor can send a block of data 
at a high rate. The UPI can then output characters 
from the buffer at a rate the printer can accept while 
the master processor returns to other tasks. 



The 8295 Printer Controller is an example of an 
8041A preprogrammed as a dot matrix printer inter- 
face. 

Tape Cassette Controller 

Figure 6-3 illustrates a digital cassette interface 
which can be implemented with the UPI-41A. Two 
sections of the tape transport are controlled by the 
UPI: digital data/command logic, and motor servo 
control. 

The motor servo requires a speed reference in the 
form of a monostable pulse whose width is propor- 
tional to the desired speed. The UPI monitors a 
prerecorded clock from the tape and uses its on- 
board interval timer to generate the required speed 
reference pulses at each clock transition. 

Recorded data from the tape is supplied serially by 
the data/command logic and is converted to 8-bit 
words by the UPI, then transferred to the master 
processor. At 10 ips tape speed the UPI can easily 
handle the 8000 bps data rate. To record data, the 
UPI uses the two input lines to the data/command 
logic which control the flux direction in the record- 
ing head. The UPI also monitors 4 status lines from 
the tape transport including: end of tape, cassette 
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Figure 6-2. Matrix Printer Controller 
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Figure 6-3. Tape Transport Controller 



inserted, busy, and write permit. All control signals 
can be handled by the UPFs two I/O ports. 

Universal I/O Interface 

Figure 6-4 shows an I/O interface design based on 
the UPI. This configuration includes 12 parallel I/O 
lines and a serial (RS232C) interface for full duplex 
data transfer up to 1200 baud. This type of design 
can be used to interface a master processor to a 
broad spectrum of peripheral devices as well as to a 
serial communication channel. 



PORT 1 is used strictly for I/O in this example while 
PORT 2 lines provide five functions: 

• P23-P2O I/O lines (bidirectional) 

• P24 Request to send (RTS) 

• P25 Clear to Send (CTS) 

• P26 Interrupt to master 

• P27 Serial data out 

The parallel I/O lines make use of the bidirectional 
port structure of the UPI. Any line can function as 
an input or output. All po rt lines a re automatically 
initialized to 1 by a system RESET pulse and remain 
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Figure 6-4. Universal I/O Interface 
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latched. An external TTL signal connected to a port 
line will override the UPFs 50K-ohm internal pull- 
up so that an INPUT instruction will correctly sam- 
ple the TTL signal. 

Four PORT 2 lines function as general I/O similar to 
PORT 1. Also, the RTS signal is generated on PORT 
2 under software control when the UPI has serial 
data to send. The CTS signal is monitored via PORT 
2 as an enable to the UPI to send serial data. A 
PORT 2 line is also used as a software generated in- 
terrupt to the master processor. The interrupt func- 
tions as a service request when the UPI has a byte of 
data to transfer or when it is ready to receive. Alter- 
natively, the EN FLAG S ins truction could be used 
to create the OBF and IBF interrupts on P24 and 
P25. 

The RS232C interface is implemented using the 
TEST pin as a receive input and a PORT 2 pin as a 
transmit output. External packages (Aq, Ai) are 
used to provide RS232C drive requirements. The 
serial receive software is interrupt driven and uses 
the on-chip timer to perform time critical serial con- 
trol. After a start bit is detected the interval timer 



can be preset to generate an interrupt at the proper 
time for sampling the serial bit stream. This elimi- 
nates the need for software timing loops and allows 
the processor to proceed to other tasks (i.e., parallel 
I/O operations) between serial bit samples. Software 
flags are used so the main program can determine 
when the interrupt driven receive program has a 
character assembled for it. 

This type of configuration allows system designers 
flexibility in designing custom I/O interfaces for spe- 
cific serial and parallel I/O applications. For in- 
stance, a second or third serial channel could be 
substituted in place of the parallel I/O if required. 
The UPFs data memory can buffer data and com- 
mands for up to 4 low-speed channels (110 baud tele- 
typewriter, etc.) 



Application Notes 

The following application notes illustrate the var- 
ious applications of the UPI family. Other related 
publications including the 8048 Family Application 
Handbook are available through the Intel Literature 
Department. 
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INTRODUCTION TO THE UPI-41Atm 

Introduction 

Since the introduction in 1974 of the second genera- 
tion of microprocessors, such as the 8080, a wide 
range of peripheral interface devices have appeared. 
At first, these devices solved application problems of 
a general nature; i.e., parallel interface (8255), serial 
interface (8251), timing (8253), interrupt control 
(8259). However, as the speed and density of LSI 
technology increased, more and more intelligence 
was incorporated into the peripheral devices. This 
allowed more specific application problems to be 
solved, such as floppy disk control (8271), CRT con- 
trol (8275), and data link control (8273). The advan- 
tage to the system designer of this increased 
peripheral device intelligence is that many of the pe- 
ripheral control tasks are now handled externally to 
the main processor in the peripheral hardware 
rather than internally in the main processor soft- 
ware. This reduced main processor overhead results 
in increased system throughput and reduced soft- 
ware complexity. 

In spite of the number of peripheral devices avail- 
able, the pervasiveness of the microprocessor has 
been such that there is still a large number of periph- 
eral control applications not yet satisfied by dedi- 
cated LSI. Complicating this problem is the fact that 
new applications are emerging faster than the manu- 
facturers can react in developing new, dedicated pe- 
ripheral controllers. To address this problem, a new 
microcomputer-based Universal Peripheral Inter- 
face (UPI-41A) device was developed. 



requirements allow them to either stand alone or be 
incorporated as just one task in a "multi-tasking" 
UPI, and applications which are complete UPI ap- 
plications in themselves. Applications in the first 
group are a simple LED display and sensor matrix 
controllers. A combination serial/parallel/ I/O de- 
vice is an application in the second group. Each ap- 
plication illustrates different UPI configurations 
and features. However, before the application de- 
tails are presented, a section on the UPI/master pro- 
tocol requirements is included. These protocol 
requirements are key to UPI software development. 
For convenience, the UPI block diagram is repro- 
duced in Figure 1 and the instruction set summary 
in Table 1. 

UPI-41 vs. UPI-41A 

The UPI-41 A is an enhanced version of the UPI-41. 
It incorporates several architectural features not 
found on the "non-A" device: 

• Separate Data In and Data Out data bus buf- 
fer registers 

• User-definable STATUS register bits 

• Pro gram mable master interrupts for the OBF 
and IBF flags 

• Programmable DMA interface to external 
DMA controller. 

The separate Data In (DBBIN) and Data Out 
(DBBOUT) registers greatly simplify the master/ 
UPI protocol compated to the UPI-41. The master 
need only check IBF before writing to DBBIN and 
OBF before reading DBBOUT. No data bus buffer 
lock-out is required. 



In essence, the UPI-41A acts as a slave processor to 
the main system CPU. The UPI contains its own 
processor, memory, and I/O, and is completely user 
programmable; that is, the entire peripheral control 
algorithm can be programmed locally in the UPI, in- 
stead of taxing the master processor's main memory. 
This distributed processing concept allows the UPI 
to handle the real-time tasks such as encoding key- 
boards, controlling printers, or multiplexing dis- 
plays, while the main processor is handling non-real- 
time dependent tasks such as buffer management or 
arithmetic. The UPI relies on the master only for 
initialization, elementary commands, and data 
transfers. This technique results in an overall in- 
crease in system efficiency since both processors — 
the master CPU and the slave UPI — are working in 
parallel. 

This application note presents three UPI-41A appli- 
cations which are roughly divided into two groups: 
applications whose complexity and UPI code space 



The most significant nibble of the STATUS register, 
undefined in the UPI-41, is user-definable in UPI- 
41 A. It may be loaded directly from the most signifi- 
cant nibble of the Accumulator (MOV STS,A). 
These extra four STATUS bits are useful for trans- 
ferring additional status information to the master. 
This application note uses this feature extensively. 

A new instruction, EN FLAGS, allows OBF and IBF 
to be reflected on PORT 2 BIT 4 and PORT 2 BIT 5 
respectively. This feature enables interrupt-driven 
data transfers when these pins are interrupt sources 
to the master. 

By executing an EN DMA instruction PORT 2 BIT 
6 becomes a DRQ (DM A Requ est) output and 
PORT 2 BIT 7 becomes DACK (DMA Acknowl- 
edge). Setting DRQ requests a DMA cycle to an ex- 
ternal DMA controller. When the cycle is granted, 
the DMA controller returns DACK plus either RD 
(Read) or WR (Write). DACK automatically forces 
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Figure 1A. Program Memory Map 



Figure IB. Data Memory Map 



CS and Aq low internally and clears DRQ. This se- 
lects the appro pria te data buffer register (D BBO UT 
for BACK and RD, DBBIN for BACK and WR) for 
the BMA transfer. 

Like the "non-A", the UPI-41A is available in both 
ROM (8041A) and EPROM (8741A) Program Mem- 
ory versions. This application note deals exclusively 
with the UPI-41A since the applications use the "A"s 
enhanced features. 



UPI/MASTER PROTOCOL 

As in most closely coupled multiprocessor systems, 
the various processors communicate via a shared re- 
source. This shared resource is typically specific lo- 
cations in RAM or in registers through which status 
and data are passed. In the case of a master proces- 
sor and a UPI-41 A, the shared resource is 3 separate, 
master-addressable, registers internal to the UPI. 
These registers are the status register (STATUS), 
the Bata Bus Buffer Input register (BBBIN), and 
the Bata Bus Output register (BBBOUT). [Bata 
Bus Buffer direction is relative to the UPI]. To illus- 
trate this register interface, consider the 8085AAJPI 
system in Figure 2. 



Looking into the UPI from the 8085A, the 8085A 
sees only the three registers mentioned above. If the 
8085A wishes to issue a command to the UPI, it does 
so by writing the command to the BBBIN register 
according to the decoding of Table 2. Bata for the 
UPI is also passed via the BBBIN register. (The UPI 
differentiates commands and data by examining the 
Aq pin. Just how this is done is covered shortly.) 
Bata from the UPI for the 8085A is passed in the 
BBBOUT register. The 8085A may interrogate the 
UPFs status by reading the UPFs STATUS register. 
Four bits of the STATUS register act as flags and 
are used to handshake data and commands into and 
out of the UPI. The STATUS register format is 
shown in Figure 3. 

BIT is OBF (Output Buffer Full). This flag indi- 
cates to the master when the UPI has placed data in 
the BBBOUT register. OBF is set when the UPI 
writes to BBBOUT and is reset when the master 
reads BBBOUT. The master finds meaningful data 
in the BBBOUT register only when OBF is set. 

The Input Buffer Full (IBF) flag is BIT L The UPI 
uses this flag as an indicator that the master has 
written to the BBBIN register. The master uses IBF 
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Figure 1C. UPI-41A Block Diagram 



to indicate when the UPI has accepted a particular 
command or data byte. The master should examine 
IBF before outputting anything to the UPI. IBF is 
set when the master writes to DBBIN and is reset 
when the UPI reads DBBIN. The master must wait 
until IBF=0 before writing new data or commands 
to DBBIN. Conversely, the UPI must ensure IBF=1 
before reading DBBIN. 

The third STATUS register bit is Fq (FLAG 0). This 
is a general purpose flag that the UPI can set, reset, 
and test. It is typically used to indicate a UPI error 
or busy condition to the master. 

FLAG 1 (Fi) is the final dedicated STATUS bit. 
Like Fq the UPI can set, reset, and test this flag. 
However, in addition, Fi reflects the state of the Aq 
pin whenever the master writes to the DBBIN regis- 
ter. The UPI uses this flag to delineate between mas- 
ter command and data writes to DBBIN. 

The remaining four STATUS register bits are user 
definable. Typical uses of these bits are as status in- 




Figure 2. Register Interface 

dicators for individual tasks in a multitasking UPI 
or as UPI generated interrupt status. These bits find 
a wide variety of uses in the upcoming applications. 

Looking into the 8085A from the UPI, the UPI sees 
the two DBB registers plus the IBF, OBF, and Fi 
flags. The UPI can write from its accumulator to 
DBBOUT or read DBBIN into the accumulator. 
The UPI cannot read OBF, IBF, or Fi directly, but 
these flags may be tested using conditional jump 
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Table 1. Instruction Set Summary 



Mnemonic 


Description 


Bytes Cycles | 


Accumulator 


ADD A,Rr 


Add register to A 




ADD A,@Rr 


Add data memory to A 




ADD A,#data 


Add immediate to A 




ADDC A,Rr 


Add register to A with carry 




ADDC A (SRr 


Add data memory to A with carry 




ADDC A,#data 


Add immed. to A with carry 




ANL a,Rr 


AND register to A 




ANL A,@Rr 


AND data memory to A 




ANL A,#data 


AND immediate to A 




ORL A,Rr 


OR register to A 




ORL A@Rr 


OR data memory to A 




ORL A,#data 


OR immediate to A 




XRL A,Rr 


Exclusive OR register to A 




XRL A,@Rr 


Exclusive OR data memory to A 




XRL A,#data 


Exclusive OR immediate to A 




INC A 


Increment A 




DEC A 


Decrement A 




CLRA 


Clear A 




CPLA 


Complement A 




DA A 


Decimal Adjust A 




SWAP A 


Swap digits of A 




RLA 


Rotate A left 




RLCA 


Rotate A left through carry 




RRA 


Rotate A right 




RRCA 


Rotate A right through carry 




Input/Output 1 


INA,Pp 
OUTLPp,A 


Input port to A 


1 2 


Output A to port 


1 2 


ANL Pp,#data 


AND immediate to port 


2 2 


ORL Pp,#data 
IN A,DBB 


OR immediate to port 


2 2 


Input DBB to A, clear IBF 


1 1 


OUT DBB,A 


Output A to DBB, set OBF 


1 1 


MOV STS,A 


A4-A7 to Bits 4-7 of Status 


1 1 


MOVD A,Pp 
MOVD Pp,A 


Input Expander port to A 


1 2 


Output A to Expander port 


1 2 


ANLD Pp,A 


AND A to Expander port 


1 2 


ORLD Pp,A 


OR A to Expander port 


1 2 


Data Moves 


MOV A,Rr 


Move register to A 


1 1 


MOVA,@Rr 


Move data memory to A 


1 1 


MOVA,#data 


Move immediate to A 


2 2 


MOV RpA 


Move A to register 


1 1 


MOV (S)Rr,A 


Move A to data memory 


1 1 


MOV Rr,#data 


Move immediate to register 


2 2 


MOV (a)Rr,#data 


Move immediate to data memory 


2 2 


MOV A,PSW 


Move PSW to A 


1 1 


MOV PSW,A 


Move A to PSW 


1 1 


XCH A,Rr 


Exchange A and register 


1 1 


XCH A,@Rr 


Exchange A and data memory 


1 1 


XCHD A@Rr 


Exchange digit of A and register 


1 1 


MOVP A,(g)A 


Move to A from current page 


1 2 


M0VP3, A,@A 


Move to A from page 3 


1 2 



Mnemonic 


Description 1 


Bytes Cycles 


Timer/Counter 1 


MOV A,T 


Read Timer/Counter 






MOV T,A 


Load Timer/Counter 






STRTT 


Start Timer 






STRT CNT 


Start Counter 






STOP TCNT 


Stop Timer/Counter 






EN TCNTI 


Enable Timer/Counter Interrupt 






DIS TCNTI 


Disable Timer/Counter Interrupt 






Control 1 


EN DMA 


Enable DMA Handshake Lines 






EN I 


Enable IBF Interrupt 






DIS I 


Disable IBF Interrupt 






EN FLAGS 


Enable Master Interrupts 






SEL RBO 


Select register bank 






SEL RBI 


Select register bank 1 






NOP 


No Operation 






Registers | 


INCRj 


Increment register 


1 


1 


INC @Rr 


Increment data memory 


1 


1 


DECRr 


Decrement register 


1 


1 


Subroutine | 


CALL addr 


Jump to subroutine 


2 


2 


RET 


Return 


1 


2 


RETR 


Return and restore status 


1 


2 


Flags 1 


CLRC 


Clear Carry 






CPLC 


Complement Carry 






CLRFO 


Clear Flag 






CPLFO 


Complement Flag 






CLRFl 


Clear Fl Flag 






CPLFl 


Complement Fl Flag 






Branch 


JMP ADDR 


Jump unconditional 


2 


2 


JMPP (5)A 


Jump indirect 


1 


2 


DJNZ R,addr 


Decrement register and skip 


2 


2 


JC addr 


Jump on Carry =1 


2 


2 


JNC addr 


Jump on Carry=0 


2 


2 


JZ addr 


Jump on A Zero 


2 


2 


JNZ addr 


Jump on A not Zero 


2 


2 


JTO addr 


JumponTO=l 


2 


2 


JNTO addr 


Jump on T0=0 


2 


2 


JTl addr 


Jump on Tl=l 


2 


2 


JNTl addr 


Jump on T1=0 


2 


2 


JFO addr 


Jump on FO Flag=l 


2 


2 


JFl addr 


Jump on Fl Flag=l 


2 


2 


JTF addr 


Jump on Timer Flag=l,Clear Flag 


2 


2 


JNIBF addr 


Jump on IBF Flag=0 


2 


2 


JOBF addr 


Jump on OBF Flag=l 


2 


2 


JBb addr 


Jump on Accumulator Bit 


2 


2 



Table 2. Register Decoding 



cs 


AO 


RD 


WR 


REGISTER 











1 


READ DBBOUT 





1 





1 


READ STATUS 








1 





WRITE DBBIN (DATA) 




1 


1 

X 


1 

X 



X 


WRITE DBBIN (COM- 
MAND) 

NO ACTION 



Tnr 



- OBF — DBBOUT FULL 
■ IBF — DBBIN FULL 

- FO — FLAG 

- F1 — FLAG 1 

- USER DEFINED 



STATUS REGISTER 



Figure 3. Status Register Format 
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instructions. The UPI should make sure that OBF is 
reset before writing new data into DBBOUT to en- 
sure that the master has read previous DBBOUT 
data. IBF should also be tested before reading 
DBBIN since DBBIN data is valid only when IBF is 
set. As was mentioned earlier, the UPI uses Fi to dif- 
ferentiate between command and data contents in 
DBBIN when IBF is set. The UPI may also write the 
upper 4-bits of its accumulator to the upper 4-bits of 
the STATUS register. These bits are thus user 
definable. 

The UPI can test the flags at any time during its in- 
ternal program execution. It essentially "polls" the 
STATUS register for changes. If faster response is 
needed to master commands and data, the UPI's in- 
ternal interrupt structure can be used. If IBF inter- 
rupts are enabled, a master write to DBBIN (either 
command or data) sets IBF which generates an in- 
ternal CALL to location 03H in program memory. At 
this point, working register contents can be saved 
using bank switching, the accumulator saved in a 
spare working register, and the DBBIN register read 
and serviced. The interrupt logic for the IBF inter- 
rupt is shown in Figure 4. A few observations con- 
cerning this logic are appropriate. Note that if the 
master writes to DBBIN while the UPI is still servic- 
ing the last IBF interrupt (a RETR instruction has 
not been executed), the IBF Interrupt Pending line 



is made high which causes a new CALL to 03H as 
soon as the first RETR is executed. No EN I (Enable 
Interrupt) instruction is needed to rearm the inter- 
rupt logic as is needed in an 8080 or 8085A system; 
the RETR performs this function. Also note that ex- 
ecuting a DIS I to disable further IBF interrupts 
does not clear a pending interrupt. Only a CALL to 
location 03H or RESET clears a pending IBF inter- 
rupt. 

Keeping in mind that the actual master/UPI proto- 
col is dependent on the application, probably the 
best way to illustrate correct protocol is by example. 
Let's consider using the UPI as a simple parallel I/O 
device. (This is a trivial application but it embodies 
all of the important protocol considerations.) Since 
the UPI may be either interrupt or non-interrupt 
driven internally, both cases are considered. 

Let's take the easiest configuration first; using the 
UPI PORT 1 as an 8-bit output port. From the UPI's 
point- of -view, this is an input-only application since 
all that is required is that the UPI input data from 
the master. Once the master writes data to the UPI, 
the UPI reads the DBBIN register and transfers the 
data to PORT 1. No testing for commands versus 
data is needed since the UPI "knows" it only per- 
forms one task — no commands are needed. 
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Figure 4. UPI-41A Interrupt Structure 
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Non-interrupt driven UPI software is shown in Fig- 
ure 5A while Figure 5B shows interrupt based soft- 
ware. For Figure 5A, the UPI simply waits until it 
sees IBF go high indicating the master has written a 
data byte to DBBIN. The UPI then reads DBBIN, 
transfers it to PORT 1, and returns to waiting for the 
next data. For the interrupt-driven UPI, Figure 5B, 
once the EN I instruction is executed, the UPI sim- 
ply waits for the IBF interrupt before handling the 
data. The UPI could handle other tasks during this 
waiting time. When the master writes the data to 
DBBIN, an IBF interrupt is generated which per- 
forms a CALL to location 03H. At this point the UPI 
reads DBBIN (no testing of IBF is needed since an 
IBF interrupt implies that IBF is set), transfers the 
data to PORT 1, and executes an RETR which re- 
turns program flow to the main program. 



Software for the master 8085A is included in Figure 
5C. The only requirement for the master to output 
data to the UPI is that it check the UPI to be sure 
the previous data had been taken before writing new 
data. To accomplish this the master simply reads the 
STATUS register looking for IBF=0 before writing 
the next data. 



UPI INPUT ONLY EXAMPLE— PORT 1 USED AS OUTPUT PORT 
UPI POLLS IBF FOR DATA 



JNIBF RESET 

IN A.DBB 

OUTL P1.A 

JMP RESET 



WAIT ON IBF FOR INPUT 
INPUT THERE. SO READ IT 
TRANSFER DATA TO PORT 1 
GO WAIT FOR NEXT DATA 



Figure 5A. Single Output Port Example — Polling 



; UPI INPUT ONLY EXAMPLE— PORT 1 USED AS OUTPUT PORT 


; DATA INPUT IS INTERRUPT-DRIVEN ON IBF 


RESET: EN 1 


ENABLE IBF INTERRUPTS 


JMP RESET+1 


LOOP WAITING FOR INPUT 


IBFINT: IN A.DBB 


READ DATA FROM DBBIN 


OUTL P1.A 


TRANSFER DATA TO PORT 1 


RETR 


RETURN WITH RESTORE 



Figure 5B. Single Output Port Example — Interrupt 



; 8085 SOFTWARE FOR UPI INPUT-ONLY EXAMPLE 


; DATA FOR OUTPUT IS PASSED IN REG. C 


UPIOUT: IN 


STATUS ; READ UPI STATUS | 


ANI 


IBF 


LOOK AT IBF 


JNZ 


UPIOUT 


WAIT FOR IBF=0 


MOV 


A.C 


GET DATA FROM C 


OUT 


DBBIN 


OUTPUT DATA TO DBBIN 


RET 




DONE. RETURN 



Figure 50. 8085A Oode for Single Output Port Ex- 
ample 



Figure 6A illustrates the case where UPI PORT 2 is 
used as an 8-bit input port. This configuration is 
termed UPI output-only as the master does not 
write (input) to the UPI but simply reads either the 
STATUS or the DBBOUT registers. In this example 
only the OBF flag is used. OBF signals the master 
that the UPI has placed new port data in DBBOUT. 
The UPI loops testing OBF. When OBF is clear, the 
master has read the previous data and UPI then 
reads its input port (PORT 2) and places this data in 
DBBOUT. It then waits on OBF until the master 
reads DBBOUT before reading the input port again. 
When the master wishes to read the input port data. 
Figure 6B, it simply checks for OBF being set in the 
STATUS register before reading DBBOUT. While 
this technique illustrates proper protocol, it should 
be noted that it is not meant to be a good method of 
using the UPI as an input port since the master 
would never get the newest status of the port. 



UPI OUTPUT ONLY EXAMPLE— PORT 2 USED AS INPUT PORT 
PORT DATA IS AVAILABLE IN DBBOUT 



JOBF RESET 

IN A,P2 

OUT DBB.A 

JMP RESET 



LOOP IF 0BF=1 (DATA NOT READ) 
DBBOUT CLEAR. READ PORT 
TRANSFER PORT DATA TO DBBOUT 
WAIT FOR MASTER TO READ DATA 



Figure 6A. Single Input Port Example 



8085 SOFTWARE FOR UPI OUTPUT— ONLY EXAMPLE 
INPUT DATA RETURNED IN REG. A 



IN 
ANI 
JZ 
IN 



STATUS 
OBF 
UPIIN 
DBBOUT 



READ UPI STATUS 
LOOK AT OBF 
WAIT UNTIL 0BF=1 
READ DBBOUT 
RETURN WITH DATA IN A 



Figure 6B. 8085A Single Input Port Code 

The above examples can easily be combined. Figure 
7 shows UPI software to use PORT 1 as an output 
port simultaneously with PORT 2 as an input port. 
The program starts with the UPI checking IBF to 
see if the master has written data destined for the 
output port into DBBIN. If IBF is set, the UPI reads 
DBBIN and transfers the data to the output port 
(PORT 1). If IBF is not set or once the data is trans- 
ferred to the output port if it was, OBF is tested. If 
OBF is reset (indicating the master has read 
DBBOUT), the input port (PORT 2) is read and 
transferred to DBBOUT. If OBF is set, the master 
has yet to read DBBOUT so the program just loops 
back to test IBF. 

The master software is identical to the separate 
input/output examples; the master must test IBF 
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; UPI INPUT /OUTPUT EXAMPLE- 


-PORT 10UTPUT. PORT 2 INPUT 


RESET: 


JNIBF 0UT1 


IF IBF=0, DO OUTPUT 




IN A. DBB 


IFIBF=1.READDBBIN 




OUTL PI. A 


TRANSFER DATA TO PORT 1 


0UT1: 


JOBF RESET 


IF0BF=1,G0TESTIBF 




IN A. P2 


IF OBF=0. READ PORT 2 




OUT DBB, A 


TRANSFER PORT DATA TO DBBOUT 




JMP RESET 


GO CHECK FOR INPUT 



Figure 7. Combination Output/ Input Port Example 



and OBF before writing output port data into 
DBBIN or before reading input port from DBBOUT 
respectively. 

In all of the three examples above, the UPI treats 
information from the master solely as data. There 
has been no need to check if DBBIN information is a 
command rather than data since the applications do 
not require commands. But what if both PORTs 1 
and 2 were used as output ports? The UPI needs to 
know into which port to put the data. Let's use a 
command to select which port. 

Recall that both commands and data pass through 
DBBIN. The state of the Aq pin at the time of the 
write to DBBIN is used to distinguish commands 
from data. By convention, DBBIN writes with Ao=0 
are for data, and those with Ao=l are commands. 
When DBBIN is written into, Fi (FLAG 1) is set to 
the state of Aq. The UPI tests Fi to determine if the 
information in the DBBIN register is data or 
command. 

For the case of two output ports, let's assume that 
the master selects the desired port with a command 
prior to writing the data. (We could just use Fi as a 
port select but that would not illustrate the subtle 
differences between commands and data). Let's de- 
fine the port select commands such that BIT 1=1 if 
the next data is for PORT 1 (Write PORT 1=0000 
0010) and BIT 2=1 if the next data is for PORT 2 
(Write PORT 2=0000 0100). (The number of the set 
bit selects the port.) Any other bits are ignored. This 
assignment is completely arbitrary; we could use any 
command structure, but this one has the advantage 
of being simple. 



UPI DUAL OUTPUT PORT EXAMPLE— BOTH PORT 1 AND 2 OUTPUTS 
COMMAND SELECTS DESIRED PORT 
WRITE PORT 1-0000 0010 (02H) 
WRITE PORT 2-0000 0100 (04H) 

FLAG USED TO REMEMBER WHICH PORT WAS SELECTED 
BY LAST COMMAND. 



RESET: 


JNIBF 


RESET 


; WAIT FOR MASTER INPUT 




IN 


A, DBB 


; READ INPUT 




JF1 


CMD 


; IF F1 = 1, COMMAND INPUT 




JFO 


P0RT2 


; INPUT IS DATA. TEST FO 




OUTL 


P1,A 


; F0=0, SO OUTPUT TO PORT 1 




JMP 


RESET 


; WAIT FOR NEXT INPUT 


P0RT2: 


OUTL 


P2,A 


; F0=1, SO OUTPUT TO PORT 2 




JMP 


RESET 


; WAIT FOR NEXT INPUT 


CMD: 


JB1 


PT1 


; TEST COMMAND BITS (BIT 1) 




JB2 


PT2 


; TEST BIT 2 




JMP 


RESET 


; NEITHER BIT SET, WAIT FOR INPUT 


PT1: 


CLR 


FO 


; PORT 1 SELECTED. CLEAR FO 




JMP 


RESET 


; WAIT FOR INPUT 


PT2: 


CLR 


FO 


; PORT 2 SELECTED, SET FO 




CPL 


FO 






JMP 


RESET 


; WAIT FOR INPUT 



Figure 8A. Dual Output Port Example 



Initially, the UPI simply waits until IBF is set indi- 
cating the master has written into DBBIN. Once 
IBF is set, DBBIN is read and Fi is tested for a com- 
mand. If Fi=l, the DBBIN byte is a command. As- 
suming a command, BIT 1 is tested to see if the 
command selected PORT 1. If so, Fq is cleared and 
the program returns to wait for the data. If BIT 1=0, 
BIT 2 is tested. If BIT 2 is set, PORT 2 is selected so 
Fq is set. The program then loops back waiting for 
the next master input. This input is the desired port 
data. If BIT 2 was not set, Fq is not changed and no 
action is taken. 

When IBF=1 is again detected, the input is again 
tested for command or data. Since it is necessarily 
data, DBBIN is read and Fq is tested to determine 
which port was previously selected. The data is then 
output to that port, following which the program 
waits for the next input. Note that since Fq still se- 
lects the previous port, the next input could be more 
data for that port. The port selection command 
could be thought of as a port select flip-flop control; 
once a selection is made, data may be repeatedly 
written to that port until the other port is selected. 
Master software. Figure 8B, simply must check IBF 
before writing either a command or data to DBBIN. 
Otherwise, the master software is straightforward. 



Note that the UPI must "remember" from DBBIN 
write to write which port has been selected. Let's use 
Fo (FLAG 0) for this purpose. If a Write PORT 1 
command is received, Fq is reset. If the command is 
Write PORT 2, Fq is set. When the UPI finds data in 
DBBIN, Fo is interrogated and the data is loaded 
into the previously selected port. The UPI software 
is shown in Figure 8A. 



For the sake of completeness, UPI software for im- 
plementing two input ports is given in Figure 9. This 
case is simpler than the dual output case since the 
UPI can assume that all writes to DBBIN are port 
selection commands so no command/data testing is 
required. Once the Port Read command is input, the 
selected port is read and the port data is placed in 
DBBOUT. Note that in this case Fq is used as a UPI 
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error indicator. If the master happened to issue an 
invalid command (a command without either BIT 1 
or 2 set), Fq is set to notify the master that the UPI 
did not know how to interpret the command. Fq is 
also set if the master commanded a port read before 
it had read DBBOUT from the previous command. 
The UPI simply tests OBF just prior to loading 
DBBOUT and if 0BF=1, Fq is set to indicate the 
error. 

All of the above examples are, in themselves, rather 
trivial applications of the UPI although they could 
easily be incorporated as one of several tasks in a 
UPI handling multiple small tasks. We have covered 
them primarily to introduce the UPI concept and to 
illustrate some master AJPI protocol. Before moving 
on to more realistic UPI applications, let's discuss 
two UPI features that do not directly relate to the 
master/UPI protocol but greatly enhance the UPFs 
transfer capability. 

In addition to the OBF and IBF bits in the STATUS 
register, these flags can also be made available di- 
rectly on two port pins. These port pins can then be 
used as interrupt sources to the master. By execut- 
ing an EN FLAGS instruction, PORT 2 pin 4 re- 
flects the condition of OBF and PORT 2 pin 5 
reflects the inverted condition of IBF (IBF). These 
dedicated outputs can then be enabled or disabled 
via their respective port bit values; i.e., P24 reflects 
OBF as long as an instruction is executed which sets 
P24j(i^ ORL P2,#10H). The same action applies to 
the IBF output except P25 is used. Thus P24 may 
serve as a DATA AVAILABLE interrupt output. 
Likewise for P25 as a READY-TO-ACCEPT-DATA 
interrupt. This greatly simplifies interrupt-driven 
master-slave data transfers. 



; 8085 SOFTWARE FOR DUAL OUTPUT PORT EXAK/FPLE 




THIS ROUTINE WRITES DATA IN REG. C TO PORT 1 




(SAME ROUTINE FOR PORT 2-JUST CHANGE COMMAND) 


P0RT1 


IN 


STATUS 


READ UPI STATUS 




ANI 


IBF 


LOOK AT IBF 




JNZ 


P0RT1 


WAIT UNTIL IBF=0 




MVI 


A, 0000001 OB 


LOAD WRITE P0RT1 CMD 




OUT 


UPICMD 


OUTPUT TO UPI COMMAND PORT 


P1: 


IN 


STATUS 


READ UPI STATUS AGAIN 




ANI 


IBF 


LOOK AT IBF 




JNZ 


PI 


WAIT UNTIL COMMAND ACCEPTED 




MOV 


A, C 


GET DATA FROM 




OUT 


DBBIN 


OUTPUT TO DBBIN 




RET 




DONE, RETURN 



Figure 8B. 8085A Dual Output Port Example Code 



The UPI also supports a DMA transfer interface. If 
an EN DMA instruction is executed, PORT 2 pin 6 
becomes a DMA Request (DRQ) output and P27 be- 
comes a high impedance DMA Acknowledge 



; UPI DUAL INPUT PORT EXAMPLE— BOTH PORT 1 AND 2 INPUTS 


; COMMAND SELECTS WHICH PORT IS TO BE READ 


; FLAG USED AS ERROR FLAG 


RESET: JNIBF 


RESET 


WAIT FOR INPUT 


CLR 


FO 


CLEAR ERROR FLAG 


IN 


A, DBB 


READ INPUT (COMMAND) 


JB1 


PT1 


TEST BIT 1 (PORT 1) 


JB2 


PT2 


TEST BIT 2 (PORT 2) 


ERROR: CPL 


FO 


ERROR— COMPLEMENT FO 


JMP 


RESET 


WAIT FOR INPUT 


PT1: IN 


A, P1 


READ PORT 1 


JOBF 


ERROR 


TEST OBF BEFORE LOADING DBBOUT 


OUT 


DBB, A 


LOAD PORT 1 DATA INTO DBBOUT 


JMP 


RESET 


WAIT FOR INPUT 


PT2: IN 


A, P2 


READ PORT 2 


JOBF 


ERROR 


TEST OBF BEFORE LOADING DBBOUT 


OUT 


DBB. A 


LOAD PORT 2 DATA INTO DBBOUT 


JMP 


RESET 


WAIT FOR INPUT 



Figure 9. Dual Input Port Example 



(DACK) input. Any instruction which would nor- 
mally s et P26 now sets DRQ. D RQ is cleared when 
DACK is low and either RD or WR is low. When 
DACK is low, CS and AO are forced low internally 
which allows data bus transfers between DBBOUT 
or D BBIN to occur, depending upon whether WR or 
RD is true. Of course, the function requires the use 
of an external DMA controller. 

Now that we have discussed the aspects of the UPI 
protocol and data transfer interfaces, let's move on 
to the actual applications. 

EXAMPLE APPLICATIONS 

Each of the following three sections presents the 
hardware and software details of a UPI application. 
Each application utilizes one of the protocols men- 
tioned in the last section. The first example is a sim- 
ple 8-digit LED display controller. This application 
requires only that the UPI perform input operations 
from the DBBIN; DBBOUT is not used. The reverse 
is true for the second application: a sensor matrix 
controller. The final application involves both 
DBBOUT and DBBIN operations: a combination 
serial/parallel I/O device. 

The core master processor system with which these 
applications were developed is the iSBC 80/30 single 
board computer. This board provides an especially 
convenient UPI environment since it contains a 
dedicated socket specifically interfaced for the UPI- 
41A. The 80/30 uses the 8085A as the master proces- 
sor. The I/O and peripheral complement on the 
80/30 include 12 vectored priority interrupts (8 on 
an 8259 Programmable Interrupt Controller and 4 
on the 8085 A itself), an 8253 Programmable Interval 
Timer supplying three 16-bit programmable timers 
(one is dedicated as a programmable baud rate gen- 
erator), a high speed serial channel provided by a 
8251 Programmable USART, and 24 parallel I/O 
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lines implemented with an 8255A Programmable 
Parallel Interface. The memory complement con- 
tains 16K bytes of RAM using 2117 16K bit Dynamic 
RAMs and the 8202 Dynamic RAM Controller, and 
up to 8K bytes of ROM/EPROM with sockets com- 
patible with 2716, 2758, or 2332 devices. The 80/30's 
RAM uses a dual port architecture. That is, the 
memory can be considered a global system resource, 
accessible from the on-board 8085A as well as from 
remote CPUs and other devices via the 
MULTIBUS. The 80/30 contains MULTIBUS con- 
trol logic which allows up to 16 80/30s or other bus 
masters to share the same system bus. (More de- 
tailed information on the iSBC 80/30 and other 
iSBC products may be found in the latest Intel 
Systems Data Catalog.) 

A block diagram of the iSBC 80/30 is shown in Fig- 
ure 10. Details of the UPI interface are shown in Fig- 
ure 11. This interface decodes the UPI registers in 
the following format: 



Register 

Read STATUS 

Write DBBIN (command) 

Read DBBOUT (data) 

Write DBBIN (data) 



Operations 

INE5H 
OUT E5H 

INE4H 
OUT E4H 



8-Digit Multiplexed LED Display 

The traditional method of interfacing an LED dis- 
play with a microprocessor is to use a data latch 
along with a BDC-to-7-segment decoder for each 
digit of the display. Thus two ICs, seven current 
limiting resistors, and about 45 connections are re- 
quired for each digit. These requirements are, of 
course, multiplied by the total number of digits de- 
sired. The obvious disadvantages of this method are 
high parts count and high power dissipation since 
each digit is "ON" continuously. Instead, a scheme 
of time multiplexing the display can be used to de- 
crease both parts count and power dissipation. 

Display multiplexing basically involves connecting 
the same segment (a, b, c, d, e, f , or g) of each digit in 
parallel and driving the common digit element (an- 
ode or cathode) of each digit separately. This is 
shown schematically in Figure 12. The various digits 
of the display are not all on at once; rather, only one 
digit at a time is energized. As each digit is ener- 
gized, the appropriate segments for that digit are 
turned on. Each digit is enabled in this way, in se- 
quence, at a rate fast enough to ensure that each 
digit appears to be "ON" continuously. This implies 
that the display must be "refreshed" at periodic in- 
tervals to keep the digits flicker-free. If the CPU had 
to handle this task, it would have to suspend normal 



processing, go update the display, and then return to 
its normal flow. This extra burden is ideally handled 
by a UPI. The master CPU could simply give charac- 
ters to the UPI and let the UPI do the actual seg- 
ment decoding, display multiplexing, and 
refreshing. 

As an example of this technique. Figure 13 shows the 
UPI controlling an 8-digit LED display. All digit 
segments are connected in parallel and are driven 
through segment drivers by the UPI PORT 1. The 
lower 3 bits of PORT 2 are inputs to a 3-to-8 decoder 
which selects an individual digit through a digit 
driver. A fourth PORT 2 line is used as a decoder 
enable input. The remaining PORT 2 lines plus the 
TEST and TEST 1 inputs are available for other 
tasks. 

Internally, the UPI uses the counter/timer in the in- 
terval timer mode to define the interval between dis- 
play refreshes. Once the timer is loaded with the 
desired interval and started, the UPI is free to han- 
dle other tasks. It is only when a timer overflow in- 
terrupt occurs that the UPI handles the short 
display multiplexing routine. The display multiplex- 
ing can be considered a background task which is en- 
tirely interrupt-driven. The amount of time spent 
multiplexing is such that there is ample time to han- 
dle a non-timer task in the UPI foreground. (We'll 
discuss this timing shortly.) 

When a timer interrupt occurs, the UPI turns off all 
digits via the decoder enable. The next digit's seg- 
ment contents are retrieved from the internal data 
memory and output via PORT 1 to the segment 
drivers. Finally, the next digit's location is placed on 
PORT 2 (P20-P22) and the decoder enabled. This 
displays the digit's segment information until the 
next interrupt. The timer is then restarted for the 
next interval. This process continues repeatedly for 
each digit in sequence. 

As a prelude to discussing the UPI software, let's ex- 
amine the internal data memory structure used in 
this application. Figure 14. This application requires 
only 14 of the 64 total data memory locations. The 
top eight locations are dedicated to the Display 
Map; one location for each digit. These locations 
contain the segment and decimal point information 
for each character. Just how characters are loaded 
into this section of memory is covered shortly. Regis- 
ter R7 of Register Bank 1 is used as the temporary 
Accumulator store during the interrupt service 
routines. Register R3 stores the digit number of the 
next digit to be displayed. R2 is a temporary storage 
register for characters during input routine. Rq is 
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Figure 10. iSBC 80/30 Block Diagram 



the offset pointer pointing to the Display Map loca- 
tion of the next digit. That makes 12 locations so far. 
The remaining two locations are the two stack loca- 
tions required to store the return address plus status 
during the timer and input interrupt service 
routines. The remaining unused locations, all of 
Register Bank 0, 14 bytes of stack, 4 in Register 
Bank 1, and 24 general purpose RAM locations, are 
all available for use by any foreground task. 



The UPI software consists of only three short 
routines. One, INIT, is used strictly during 
initialization. DISPLA is the multiplexing routine 
called at a timer interrupt. INPUT is the character 
input handler called at an IBF interrupt. The flow 



charts for these routines are shown in Figures 14 A 
through 14C. 



INIT initializes the UPI by simply turning off all 
segment and digit drivers, filling the Display Map 
with blank characters, loading and starting the 
timer, and enabling both timer and IBF interrupts. 
Although the flow chart shows the program looping 
at this point, it is here that the code for any fore- 
ground task is inserted. The only restrictions on this 
foreground task are that it not use I/O lines dedi- 
cated to the display and that it not require dedicated 
use of the timer. It could share the timer if precau- 
tions are taken to ensure that the display will still be 
refreshed at the required interval. 
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Figure 11. UPI Interface on iSBC 80/30 
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Figure 13. UPI Controlled 8-Digit LED Display 



DISPLAY MAP 
8X8 


R7 
R6 
R5 
R4 
R3 
R2 
R1 
RO 




USER RAM 

24X8 
(NOT USED) 




ACCUMULATOR STORE 




NOT USED 




NOT USED 




NOT USED 


REGISTER 


DIGIT COUNTER 




TEMPORARY STORE 




NOT USED 




DISPLAY MAP POINTER 




STACK 
16X8 




UNUSED 
8X8 


REGISTER 
BANKO 



INITIALIZE 
REGISTERS 



TURN OFF ALL 
DRIVERS 



CLEAR DIGIT COUNTER 



LOAD AND START 
TIMER 





ENABLE TIMER AND 1 
IBF INTERRUPTS 
















WAIT LOOP OR 1 
FOREGROUND TASK CODE | 




1 



Figure 14. LED Display Controller Data Memory 
Allocation 



Figure 14A. INIT Routine Flow 



6-16 



APPLICATIONS 



















INPUT 


D 




1 








SWITCH TO RBI 
SAVE ACCUMULATOR 
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RESTORE ACCUMULATOR 
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RETURN 





















Figure 14B. INPUT Routine Fiow 



The INPUT routine handles the character input. It 
is called when an IBF interrupt occurs. After the 
usual swapping of register banks and saving of the 
accumulator, DBBIN is read and stored in register 
R2. DBBIN contains the Display Data Word. The 
format for this word, Figure 15, has two fields: Digit 
Select and Character Select. The Digit Select field 
selects the digit number into which the character 
from the Character Select field is placed. Notice that 
the character set is not limited strictly to numerics, 
some alphanumeric capability is provided. Once 
DBBIN is read, the offset for the selected digit is 
computed and placed in the Display Map Pointer 
Rq. Next the segment information for the selected 
character is found through a look-up table starting 
in page 3 of the program memory. This segment in- 
formation is then stored at the location pointed at by 
the Display Map Pointer. If the Character Select 
field specified a decimal point, the segment corre- 
sponding to the decimal point is ANDed into the 
present segment information for that digit. After the 
accumulator is restored, execution is returned to the 
main program. 



The DISPLA routine simply implements the 
multiplexing actions described earlier. It is called 
whenever a timer interrupt occurs. After saving pre- 
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1 RETURN 













Figure 14C. DiSPLA Routine Fiow 



interrupt status by switching register banks and 
storing the Accumulator, all digit drivers are turned 
off. The Display Map Pointer is then updated using 
the Current Digit Register to point at that digit's 
segment information in the Display Map. This infor- 
mation is output to PORT 1; the segment drivers. 
The number of the current digit, R3, is then sent to 
the digit select decoder and the decoder is enabled. 
This turns on the current digit. The digit counter is 
incremented and tested to see if all eight digits have 
been refreshed. If so, the digit counter is reset to 
zero. If not, nothing is done. Finally, the timer is 
loaded and restarted, the Accumulator is restored, 
and the routine returns execution to the main pro- 
gram. Thus DISPLA refreshes one digit each time it 
is CALLed by the timer interrupt. The digit remains 
on until the next time DISPLA is executed. 

The UPI software listing is included as Appendix 
Al. Appendix A2 shows the 8085 A test routine used 
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Figure 15. 



LED Display Controller Display Data 
Word Format 



to display the contents of a display buffer on the dis- 
play. The 8085A software takes care of the display 
digit numbering. Since the application is input-only 
for the UPI, the only protocol required is that the 
master must test IBF before writing a Display Data 
Word into DBBIN. 



On the iSBC 80/30, the UPI frequency is at 5.5296 
MHz. To obtain a flicker-free display, the whole dis- 
play must be refreshed at a rate of 50 Hz or greater. 



If we assume a 50 Hz refresh rate and an 8-digit dis- 
play, this means the DISPLA routine must be 
CALLed 50X8 or 400 times/sec. This transfers, using 
the timer interval of 87 ^s at 5.5296 MHz, to a timer 
count of 227. (Recall from the UPI-41A User's Man- 
ual that the timer is an "8-bit up-counter".) Hence 
the TIME equate of 227D in the UPI listing. Obvi- 
ously, different frequency sources or display lengths 
would require that this equate be modified. 

With the UPI running at 5.5296 MHz, the instruc- 
tion cycle time is 2.713 /jls. The DISPLA routine re- 
quires 28 instruction cycles, therefore, the routine 
executes in 76 ^s. Since DISPLA is CALLed 400 
times/sec, the total time spent refreshing the display 
during one second is then 30 ms or 3 % of the total 
UPI time. This leaves 97.0% for any foreground 
tasks that could be added. 



While the basic UPI software is useful just as it 
stands, there are several enhancements that could be 
incorporated depending on the application. Auto-in- 
crementing of the digit location could be added to 
the input routine to alleviate the need for the master 
to keep track of digit numbers. This could be (op- 
tionally) either right-handed or left-handed entry a 
la TI or HP calculators. The character set could be 
easily modified by simply changing the lookup table. 
The display could be expanded to 16 digits at the 
expense of one additional PORT 2 digit select line, 
the replacement of the 3-to-8 decoder with a 4-to-16 
decoder, and 8 more Display Map locations. 

Now let's move on to a slightly more complex appli- 
cation that is UPI output-only — a sensor matrix 
controller. 



Sensor Matrix Controller 

Quite often a microprocessor system is called upon 
to read the status of a large number of simple SPST 
switches or sensors. This is especially true in a proc- 
ess or industrial control environment. Alarm sys- 
tems are also good examples of systems with a large 
sensor population. If the number of sensors is small, 
it might be reasonable to dedicate a single input port 
pin for each sensor. However, as the number of sen- 
sors increase, this technique becomes very wasteful. 
A better arrangement is to configure the sensors in a 
matrix organization like that shown in Figure 16. 
This arrangement of 16 sensors requires only 4 input 
and 4 output lines; half the number needed if dedi- 
cated inputs were used. The line saving becomes 
even more substantial as the number of sensors 
increases. 
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In Figure 16, the basic operation of the matrix in- 
volves scanning individual row select lines in se- 
quence while reading the column return lines. The 
state of any particular sensor can then be deter- 
mined by decoding the row and column information. 
The typical configuration pulls up the column re- 
turn lines and the selected row is held low. De- 
selected rows are held high. Thus a return line re- 
mains high for an open sensor on the selected row 
and is pulled low for a closed sensor. Diode isolation 
is used to prevent a phantom closure which would 
occur when a sensor is closed on a selected row and 
there are two or more closures on a deselected row. 
Germanium diodes are used to provide greater noise 
margin at the return line input. 




Figure 16. 4X4 Sensor Matrix 



If the main processor was required to control such a 
matrix it would periodically have to output at the 
row port and then read the column return port. The 
processor would need to maintain in memory a map 
of the previous state of the matrix. A comparison of 
the new return information to the old information 
would then be made to determine whether a sensor 
change had occurred. Any changes would be pro- 
cessed as needed. A row counter and matrix map 
pointer also require maintenance each scan. Since in 
most applications sensors change very slowly com- 
pared to most processing actions, the processor 
probably would scan the rows only periodically with 
other tasks being processed between scans. 

Rather than require the processor to handle the 
rather mundane tasks of scanning, comparing, and 
decoding the matrix, why not use a dedicated pro- 
cessor? The UPI is perfect. 

Figure 17 shows a UPI configuration for controlling 
up to 128 sensors arranged in a 16X8 matrix. The 4- 
to-16 line decoder is used as the row selector to save 
port pins and provides the expansion to 128 sensors 
over the maximum of 64 sensors if the port had been 
used directly. It also helps increase the port drive ca- 
pability. The column return lines go directly into 
PORT 1. Features of this design include complete 
matrix management. As the UPI scans the matrix it 
compares its present status to the previous scan. If 
any change is detected, the location of the change is 
decoded and loaded, along with the sensor's present 
state, into DBBOUT. This byte is called a Change 
Word. The Master processor has only to read one 
byte to determine the status and coordinate of a 
changed sensor. If the master had not read a pre- 
vious Change Word in DBBOUT (0BF=1) before a 
new sensor change is detected, the new Change 
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Figure 17. 128 Sensor Matrix Controller 
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Word is loaded into an internal FIFO. This FIFO 
buffers up to 40 changes before it fills. The status of 
the FIFO and OBF is made available to the master 
either by polling the UPI STATUS register, Figure 
18A, or as interrupt sources on port pins P24 and 
P25 respectively, Figure 17. The FIFO NOT EMP- 
TY pin and bit are true as long as there are changes 
not yet read in the FIFO. As long as the FIFO is not 
empty, the UPI monitors OBF and loads new 
Change Words from the FIFO into DBBOUT. Thus, 
the UPI provides complete FIFO management. 



I OBF — 



OBF — CHANGE WORD READY (P25) 



■ FIFO NOT EMPTY (P24) 
- NOT USED 



Figure 18A. Sensor Matrix Status Register Format 
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Figure 18B. Sensor Matrix Ctiange Word Format 

Internally, the matrix scanning software is pro- 
grammed to run as a foreground task. This allows 
the timer/counter to be used by any background task 
although the hardware configuration leaves only 2 
inputs (TEST and TEST 1) plus 2 I/O port pins 
available. Also, to add a background task, the FIFO 
would have to be made smaller to accommodate the 
needed register and data memory space. (It would be 
possible however to turn the table here and make the 
scanning software timer/counter interrupt -driven 
where the timer times the scan interval.) 

The data memory organization for this application is 
shown in Figure 19. The upper 16 bytes form the 
Matrix Map and store the sensor states from the 
previous scan; one bit for each sensor. The Change 
Word FIFO occupies the next 40 locations. (The top 
and bottom addresses of this FIFO are treated as 
equate variables in the program so that the FIFO 
size may easily be changed to accommodate the reg- 
ister needs of other tasks.) Register Rq serves as a 
pointer into the matrix map area for comparisons 



and updates of the sensor status. Ri is a general 
FIFO pointer. The FIFO is implemented as a circu- 
lar buffer with In and Out pointer registers which 
are stored in R4 and R5 respectively. These registers 
are moved into FIFO pointer Ri for actual transfers 
into or out of the FIFO. R2 is the Row Select 
Counter. It stores the number of the row being 
scanned. 
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Figure 19. Sensor Matrix Data Memory Map 

Register R3 is the Column Counter. This counter is 
normally set to OOH; however, when a change is de- 
tected somewhere in a particular row, it is used to 
inspect each sensor status bit individually for a 
change. When a changed counter sensor bit is found, 
the Row Select Counter and Column Counter are 
combined to give the sensor's matrix coordinate. 
This coordinate is temporarily stored in the Change 
Word Store, register Rq. Register R7 is the Compare 
Result. As each row is scanned, the return informa- 
tion is Exclusive-OR*d with the return information 
from the previous scan of that row. The result of this 
operation is stored in R7. If R7 is zero, there have 
been no changes on that row. A non-zero result indi- 
cates at least one changed sensor. 

The basic program operation is shown in the flow 
chart of Figure 20. At RESET, the software ini- 
tializes the working registers, the ports, and clears 
the STATUS register. To get a starting point from 
which to perform the sensor comparisons, the cur- 
rent status of the matrix is read and stored in the 
Matrix Map. At this point, the UPI begins looking 
for changed sensors starting with the first row. 
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ENCODING 



FIFO DBBOUT 
MANAGEMENT 




Figure 20. Sensor Matrix Controller Flow Chart 



Before delving further into the flow, let's pause to 
describe the general format of the operation. The 
UPI scans the matrix one row at a time. If no 
changes are detected on a particular row, the UPI 
simply moves to the next row after checking the sta- 
tus of DBBOUT and the FIFO. If a change is de- 
tected, the UPI must check each bit (sensor) within 
the row to determine the actual sensor location. 
(More than one sensor on the scanned row could 
have changed.) Rather than test all 8 bits of the row 
before checking the DBBOUT and FIFO status 
again, the UPI performs the status check in between 
each of the bit tests. This ensures the fastest re- 
sponse to the master reading previous Change 
Words from DBBOUT and the FIFO. 

With this general overview in mind, let's go first 
thru the flow chart assuming we are scanning a row 
where no changes have occurred. Starting at the 
Scan-and-Compare section, the UPI first checks if 
the entire matrix has been scanned. If it has, the var- 
ious pointers are reset. If not, the address of the 
next row is placed on PORTs 20 thru 23. This selects 
the desired row. The state of the row is then read 
on PORT 1; the column return lines. This present 
state is compared to the previous state by retriev- 
ing the previous state from the matrix map and 
performing an Exclusive-OR with the present state. 
Since we are assuming that no change has occurred, 
the result is zero. No coordinate decoding is needed 
and the flow branches to the FIFO-DBBOUT Man- 
agement section. 

The FIFO-DBBOUT Management section simply 
maintains the FIFO and loads DBBOUT whenever 
Change Words are present in the FIFO and 
DBBOUT is clear (OBF=0). The section first tests if 
the FIFO is full. (If we assume our "no-change" row 
is the first row scanned, the FIFO obviously would 
not be full.) If it is, the UPI waits until OBF=0, at 
which point the next Change Word is retrieved from 
the FIFO and placed in DBBOUT. This "unfills" the 
FIFO making room for more Change Words. At this 
point, the Column Counter, R3, is checked. For rows 
with no changes, the Column Counter is always zero 
so the test simply falls through. (We cover the case 
for changes shortly.) Now the FIFO is tested for be- 
ing empty. If it is, there is no sense in any further 
tests so the flow simply goes back up to scan the next 
row. If the FIFO is not empty, DBBOUT is tested 
again through OBF. If a Change Word is in 
DBBOUT waiting for the master to read it, nothing 
can be done and the flow likewise branches up for 
the next row. However, if the DBBOUT is free and 
remembering that the previous test showed that the 
FIFO was not empty, DBBOUT is loaded with the 
next Change Word and the last two conditional tests 
repeat. 
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Now let's assume the next row contains several 
changed sensors. Like before, the row is selected, the 
return lines read, and the sensor status compared to 
the previous scan. Since changes have occurred, the 
Exclusive-OR result is now non-zero. Any I's in the 
result reflect the positions of the changed sensors. 
This non-zero result is stored in the Compare Result 
register, R7. At this point, the Column Counter is 
preset to 8. To determine the changed sensors' loca- 
tions, the Compare Result register is shifted bit-by- 
bit to the left while decrementing the Column 
Counter. After each shift, BIT 7 of the result is test- 
ed. If it is a one, a changed sensor has been found. 
The Column Counter then reflected the sensor's ma- 
trix column position while the Scan Row Select reg- 
ister holds it row position. These registers are then 
combined in Rg, the Change Word Store, to form the 
sensor's matrix coordinate section of the Change 
Word. The 8th bit of the Change Word Store is cod- 
ed with the sensor's present state (Figure 18). This 
byte forms the complete Change Word. It is loaded 
into the next available FIFO position. If BIT 7 of the 
Compare Result had been zero, that particular sen- 
sor had not changed and the coordinate decoding is 
not performed. 

In between each shift, test, and coordinate encode (if 
necessary), the FIFO-DBBOUT Management is 
performed. It is the Column Counter test within this 
section that routes the flow back up to the Change 
Word Encoding section if the entire Compare Result 
(row) has not been shifted and tested. 

The FIFO is implemented as a circular buffer with 
IN and OUT pointers (R4 and R5 respectively). The 
operations of the FIFO is best understood using an 
example. Figure 21. This series of figures show how 
the FIFO, DBBOUT, and OBF interact as changes 
are detected and Change Words are read by the mas- 
ter. The letters correspond to sequential Change 
Words being loaded into the FIFO. Note that the fig- 
ures show only a 4X8 FIFO however, the principles 
are the same in the 40X8 FIFO. 

Figure 21 A shows the condition where no Change 
Words have been loaded into the FIFO or DBBOUT. 
In Figure 21B a change, "A", has been detected, de- 
coded, and loaded into the FIFO at the location 
equal to the value of the FIFO-IN pointer. The 
FIFO-OUT pointer is reset to the bottom of the 
FIFO since it had reached the FIFO top. Now that a 
Change Word is in the FIFO, OBF is checked to see 
if DBBOUT is empty. Because OBF=0, DBBOUT is 
empty and the Change Word is loaded from the 
FIFO location pointed at by the FIFO-OUT pointer. 
This is shown in Figure 21C. Loading DBBOUT 
automatically sets OBF. OBF remains set until the 



master reads DBBOUT. Figures 21D and 21E show 
two more Change Words loaded into the FIFO. In 
Figure 21F the first Change Word is finally read by 
the master resetting OBF. This allows the next 
Change Word to be loaded into DBBOUT. Note that 
each time the FIFO is loaded, the FIFO-IN pointer 
increments. Each time DBBOUT is read the FIFO- 
OUT pointer increments unless there are no more 
Change Words in the FIFO. Both pointers wrap- 
around to the bottom once they reach the FIFO top. 
The remaining figures show more Change Words be- 
ing loaded into the FIFO. When the entire FIFO fills 
and DBBOUT can not be loaded (0BF=1), scanning 
stops until the master reads DBBOUT making room 
for more Change Words. 

As was mentioned earlier, two interrupt outputs to 
the master are available: Change Word Ready (P25, 
OBF) and FIFO NOT EMPTY (P24). The Change 
Word Ready interrupt simply reflects OBF and is 
handled automatically by the UPI since an EN 
FLAGS instruction is executed during initialization. 
The FIFO NOT EMPTY interrupt is generated and 
cleared as appropriate, each pass through the FIFO 
management code. 

No debouncing is provided although it could be 
added. Rather, the scan time is left as an equate 
variable so that it could be varied to account for both 
debounce time and expected sensor change rates. 
The minimum scan time for this application is 
2msec when using a 6MHz clock. Since the matrix 
controller is coded as a foreground task, scan time 
simply uses a software delay loop. 

The UPI software is included as Appendix Bl. Ap- 
pendix B2 is 8085A test software which builds a 
Change Word buffer starting at BUFSRT. This soft- 
ware simply polls the STATUS register looking for 
Change Word Ready to go true. DBBOUT is then 
read and loaded into the buffer. Now let's move on to 
an application which combines both the foreground 
and background concepts. 

Combination I/O Device 

The final UPI application was designed especially to 
add additional serial and parallel I/O ports to the 
iSBC 80/30. This UPI simulates a full-duplex UART 
(Universal Asynchronous Receiver/Transmitter) 
combined with an 8-bit parallel I/O port. Features of 
the UART include: software selectable baud rates 
(110, 300, 600, or 1200 baud), double buffering for 
both the transmitter and receiver, and receiver test- 
ing for false start bit, framing, and overrun errors. 
For parallel I/O, one 8-bit port is programmable for 
either input or output. The output port is statically 
latched and the input port is sampled. 
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Figure 21 A- J. FIFO Operation Example 
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Figure 22 shows the interface of this combination 
I/O device to the dedicated UPI socket on the iSBC 
80/30. The only external requirement is a 76.8 kHz 
source which serves as the baud rate standard. The 
internal baud rates are generated as multiples of this 
external clock. This clock is obtained from one of the 
8253 counters. Otherwise, an RS-232 driver and re- 
ceiver already available for UPI use in serial I/O ap- 
plications. Sockets are also provided for termination 
of the parallel port. 
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Figure 22. Combination I/O Device 

There are three commands for this application. 
Their format is shown in Figure 23. The CON- 
FIGURE command specifies the serial baud rate 
and the parallel I/O direction. Normally this com- 
mand is issued once during system initialization. 
The I/O command causes a parallel I/O operation to 
be performed. If the parallel port direction is out, 
the UPI expects the data byte immediately following 
an I/O command to be data for the output port. If 
the port is in the input direction, an I/O command 
causes the port to be read and the data placed in 
DBBOUT. The RESET ERROR command resets 
the serial receiver error bits in the STATUS register. 
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Figure 23. Combination I/O Command Format 

The STATUS register format is shown in Figure 24. 
Looking at each bit, BIT (OBF) is the DATA 
AVAILABLE flag. It is set whenever the UPI places 
data into DBBOUT. Since the data may come from 



either the receiver or the parallel input port, the Fq 
and Fi flags (BITs 2 and 3) code the source. Thus, 
when the master finds OBF set, it must decode Fq 
and Fi to determine the source. 



STATUS FORMAT 



^ h h . h I 



OBF— DATA AVAILABLE 

- IBF— BUSY 
-FO 

-F1 

- NOT USED 

- Tx INTERRUPT 

- FRAMING ERROR 

- OVERRUN ERROR 



OPERATION (BF = 



1) 



NO OPERATION 
PARALLEL I/O DATA 
SERIAL I/O DATA 
COMMAND ERROR 



Figure 24. STATUS Register Format 

BIT 1 (IBF) functions as a busy bit. When IBF is set, 
no writes to DBBIN are allowed. BIT 5 is the TxINT 
(Transmitter Interrupt) bit. It is asserted whenever 
the transmitter buffer register is empty. The master 
uses this bit to determine when the transmitter is 
ready to accept a data character. 

BITS 6 and 7 are receiver error flags. The framing 
error flag, BIT 6, is set whenever a character is re- 
ceived with an invalid stop bit. BIT 7, overrun error, 
is set if a character is received before the master has 
read a previous character. If an overrun occurs, the 
previous character is overwritten and lost. Once an 
error occurs, the error flag remains set until reset by 
a RESET ERROR command. A set error flag does 
not inhibit receiver operation however. 

Figure 25 shows the port pin definition for this ap- 
plication. PORT 1 is the parallel I/O port. The 
UART uses PORT 2 and the Test inputs. P20 is the 
transmitter data out pin. It is set for a mark and re- 
set for a space. P23 is a transmitter interrupt output. 
This pin has the same timing as the TxINT bit in the 
STATUS register. It is normally used in interrupt- 
driven systems to interrupt the master processor 
when the transmitter is ready to accept a new data 
character. 

The OBF flag is brought out on P24 as a master in- 
terrupt when data is available in DBBOUT. P26 is a 
diagnostic pin which pulses at four times the se- 
lected baud rate. (More about this pin later.) The re- 
ceiver data input uses the TEST input. One of the 
PORT 2 pins could have been used, however, the 
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Figure 25. Combination I/O Port Definition 

software can test the TEST in one instruction 
without first reading a port. 

The TEST 1 input is the baud rate external source. 
The UART divides this input to determine the tim- 
ing needed for the selected baud rate. The input is a 
non-synchronous 76.8 kHz source. 

Internally, when the CONFIGURE command is re- 
ceived and the selected baud rate is determined, the 
internal timer/counter is loaded with a baud rate 
constant and started in the event counter mode. 
Timer/counter interrupts are then enabled. The 
baud rate constant is selected to provide a counter 
interrupt at four times the desired baud rate. At 
each interrupt, both the transmitter and receiver are 
handled. Between interrupts, any new commands 
and data are recognized and executed. 

As a prelude to discussing the flow charts, Figure 26 
shows the register definition. Register Bank serves 
the UART receiver and parallel I/O while Register 
Bank 1 handles the UART transmitter and com- 
mands. Looking at RBO first, R3 is the receiver sta- 
tus register, RxSTS. Reflected in the bits of this 
register is the current receiver status in sequential 
order. Figure 27 shows this bit definition. BIT is 
the Rx flag. It is set whenever a possible start bit is 
received. BIT 1 signifies that the start bit is good 
and character construction should begin with the 
next received bit. BIT 1 is the Good Start flag. BIT 2 
is the Byte Finished flag. When all data bits of a 
character are received, this flag is set. When all the 
bits, data and stop bits are received, the assembled 
character is loaded into the holding register (R4 in 
Figure 27) BIT 3, the Data Ready flag, is set. The 
foreground routine which looks for commands and 
data continuously, looks at this bit to determine 
when the receiver has received a character. BITS 4 
and 5 signify any error conditions for a particular 
character. 
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Figure 26. Combination I/O Register Map 



RxSTS FORMAT 



r 



Rx FLAG— POSSIBLE START BIT 
START FLAG— GOOD START BIT 
BYTE FINISHED FLAG 
DATA READY FLAG 
FRAMING ERROR 
OVERRRUN ERROR 
I/O DIRECTION 
I/O FLAG 



Figure 27. RxSTS Register 

The parallel I/O port software uses BITS 6 and 7. 
BIT 6 codes the I/O direction specified by the last 
CONFIGURE command. BIT 7 is set whenever an 
I/O command is received. The foreground routine 
tests this bit to determine when an I/O operation has 
been requested by the master. 

As was mentioned, R4 is the receiver holding regis- 
ter. Assembled characters are held in this register 
until the foreground routine finds DBBOUT free, at 
which time the data is transferred from R4 to 
DBBOUT. R5 is the receiver tick counter. Recall 
that counter interrupts occur at four times the baud 
rate. Therefore, once a start bit is found, the receiver 
only needs to look at the data every four interrrupts 
or tick counts. R5 holds the current tick count. 

Rg is the receiver de-serializing register. Data char- 
acters are assembled in this register. Rq is preset to 
80H when a good start bit is received. As each bit is 



6-25 



APPLICATIONS 



sampled every four timer ticks, they are rotated into 
the leftmost bit of Rq. The software knows the char- 
acter assembly is complete when the original preset 
bit rotates into the carry. 

An image of the upper 4 bits of the STATUS register 
is stored in R7. These bits are the TxINT, Framing 
and Overrun bits. This image is needed since the 
UPI may load the upper 4 STATUS register bits 
from its accumulator; however, it cannot read STA- 
TUS directly. 

In Register Bank 1 (Figure 26), Rl holds the baud 
rate constant which is found from decoding the baud 
rate select bits of the CONFIGURE command. The 
counter is reloaded with this constant every timer 
tick. Like the receiver, the transmitter only needs to 
update the transmitter output every four ticks. R2 
holds the transmitter tick count. The value of R2 de- 
termines which portion of the data is being trans- 
mitted; start bit, data bits, or stop bit. The transmit 
serializer is R3. R3 holds the data character as each 
character bit is transmitted. 

R4 is the transmitter holding register. It provides 
the double buffering for the transmitter. While 
transmitting one character, it is possible to load the 
next character into R4 via DBBIN. The TxINT bit 
in STATUS and pin on PORT 2 reflect the "full- 
ness" of R4. If the holding register is empty, the in- 
terrupt bit and pin are set. They are reset when the 
master writes a new data byte for the transmitter 
into DBBIN. The transmitter status register 
(TxSTS) is R5. Like RxSTS,TxSTS contains flag 
bits which indicate the current state of the transmit- 
ter. This flag bit format is shown in Figure 28. 

TxSTS BIT is the Tx flag. It is set whenever the 
transmitter is transmitting a character. It is set from 
the beginning of the start bit until the end of the 
stop bit. BIT 1 is the Tx request flag. This bit is set 
by the foreground routine when it transfers a new 
character from DBBIN to the Tx holding register, 
R4. The transmitter software uses this flag to tell if 
new data is available. It is reset when the transmitter 
transfers the character from the holding register to 
the serializer. 



TxSTS FORMAT 



cn 



t: 



Tx FLAG — TRANSMITTING 

- REQUEST FLAG 

- PIPELINED DATA BIT 

- START BIT FLAG 

- NOT USED 



Figure 28. TxSTS Register 



BIT 2 is the pipelined Tx data bit. The transmitter 
uses a pipelining technique which sets up the next 
output level in BIT 2 after processing the current 
timer tick. The output level is always changed at the 
same point after a timer tick interrupt. This tech- 
nique ensures that no bit timing distortion results 
from different length processing paths through the 
receiver and transmitter routines. 



BIT 3 of TxSTS is the Start Bit flag. It is set by the 
transmitter when the start bit space is set up in the 
pipelined data bit. This allows the transmitter to 
differentiate between the start bit and the data bits 
on following timer ticks. 

The flow charts for this application are shown in 
Figures 29A-F. At reset, the INIT routine is exe- 
cuted which initializes the registers and port pins. 
After initialization, IBF and OBF are tested in 
MNLOOP. These flags are tested continually in this 
loop. If IBF is set, Fi is tested for command or data 
and execution is transferred to the appropriate rou- 
tine (CMD or DATA). If IBF=0, OBF is checked. If 
OBF=0 (DBBOUT is free), the Rx data ready and 
I/O flags in RxSTS are tested. If Rx data ready is set, 
the received data is retrieved from the Rx holding 
register and transferred to DBBOUT. Any error 
flags associated with that data are also transferred to 
STATUS. If the I/O flag is set and the I/O direction 
is input, PORT 1 is read and the data transferred to 
DBBOUT. In either case, Fq and Fi are set to indi- 
cate the data source. 

If IBF is set by a command write to DBBIN, CMD 
reads the command and decodes the desired oper- 
ation. If an I/O operation is specified, the I/O flag is 
set to indicate to the MNLOOP and DATA routines 
that an I/O operation is to be performed. If the com- 
mand is a CONFIGURE command, the constant for 
the selected baud rate is loaded into both Baud Rate 
Constant register and the timer/counter. The timer/ 
counter is started in the event counter mode and 
timer/counter interrupts are enabled. In addition, 
the I/O port is initialized to all l*s if the I/O direction 
bit specifies an input port. If the command is a RE- 
SET ERROR command, the two error flags in STA- 
TUS are cleared. 

If the IBF flag is set by a data write, the DATA rou- 
tine reads DBBIN and places the data in the appro- 
priate place. If the I/O flag is set, the data is for the 
output port so the port is loaded. If the I/O flag is 
reset, the data is for the UART transmitter. Data for 
the transmitter resets the TxINT bit and pin plus 
sets the Tx request flag in TxSTS. The data is trans- 
ferred to the Tx holding register, R4. 
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Figure 29A. INIT Flow Chart 



Once a CONFIGURE command is received and the 
counter started, timer/counter interrupts start oc- 
curring at four times the selected baud rate. These 
interrupts cause a vector to the TIMINT routine, 
Figure 29D. A 76.8 kHz counter input provides a 
13.02 fis counter resolution. Since it requires several 
UPI instruction cycles to reload the counter, the 
counter is set to two counts less than the desired 
baud rate and the counter is reloaded in TIMINT 
synchronous with the second low-going transition 
after the interrupt. Once the counter is reloaded, an 
output port (P26) is toggled to give an external indi- 



cation of internal counter interval This is a helpful 
diagnostic feature. After the tick sample output, the 
pipelined transmitter data in TxSTS is output to the 
TxD pin. Although this occurs every timer tick, the 
pipelined data is changed only every fourth tick. 

The receiver is now handled. Figure 29E. The Rx 
flag in RxSTS is examined to see if the receiver is 
currently in the process of receiving a character. If it 
is not, the RxD input is tested for a space condition 
which might indicate a possible start bit. If the input 
is a mark, no start bit is possible and execution 
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Figure 29B. CMD Flow Chart 



branches to the transmitter flow, XMIT. If the input 
is a space, the Rx flag is set before proceeding with 
XMIT. 

If the Rx flag is found set when entering RCV, the 
receiver is in the process of receiving a character. If 
so, the start bit flag is then tested to determine if a 
good start bit was received. The Rx tick counter is 
initialized to 4 and the Rx deserializer is set to 80H. 
A mark indicates a bad start bit; the Rx flag is reset 
to abort the reception. 

If the start bit flag is set, the program is somewhere 
in the middle of the received character. Since the 
data should be sampled every fourth timer tick, the 
tick counter is decremented and tested for zero. If 
non-zero no sample is needed and execution contin- 
ues with XMIT. If zero, the tick counter is reset to 
four. Now the byte finished flag is tested to deter- 
mine if the data sample is a data or stop bit. If reset, 
the sample is a data bit. The sample is done and the 
new bit rotated into the Rx deserializer. If this rotate 
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sets the carry, that data bit was the last so the byte 
finished flag is set. If the carry is reset, the data bit is 
not the last so execution simply continues with 
XMIT. 

Had the byte finished flag been set, this sample is for 
the stop bit. The RxD input is tested and if a space, 
the framing error flag is set. Otherwise, it is reset. 
Next, the Rx data ready flag is tested. If it is set, the 
master has not read the previous character so the 
overrun error flag is set. Then the Rx data ready flag 
is set and the received data character is transferred 
into the Rx holding register. The Rx, start bit, and 
byte finished flags are reset to get ready for the next 
character. 

Execution of the transmitter routine, XMIT, follows 
the receiver. Figure 29F. The transmitter starts by 
checking the start bit flag in TxSTS. Recall that the 
actual transmit data is output at the beginning of 
the timer routine. The start bit flag indicates wheth- 
er the current timer tick interrupt started the start 
bit. If it is set, the pipelined data output earlier in 
the routine was the start of the start bit so the flag is 
reset and the Tx tick counter is initialized. Nothing 
else is done this timer tick so the routine returns to 
the foreground. 



If the start bit flag is reset, the Tx tick counter is 
incremented and tested. The test is performed mod- 
ulo 4. If the counter mod 4 is not zero, it has not been 
four ticks since the transmitter was handled last so 
the routine simply returns. If the counter mod 4 is 
zero, it is time to handle the transmitter and the Tx 
flag is tested. 

The Tx flag indicates whether the transmitter is ac- 
tive. If the transmitter is inactive, no character is 
currently being transmitted so the Tx request flag is 
tested to see if a new character is waiting in the Tx 
buffer. If no character is waiting (Tx request 
flag=0), the Tx interrupt pin and bit are set before 
returning to the foreground. If there is a character 
waiting, it is retrieved from the buffer and placed in 
the Tx serializer. The Tx request flag is reset while 
the Tx and start bit flags are set. A space is placed in 
the Tx pipelined data bit so a start bit will be output 
on the next tick. Since the Tx buffer is now empty, 
the Tx interrupt bit and pin are set to indicate the 
availability of the buffer to the master. The routine 
then returns to the foreground. 

If the tick counter mod 4 is zero and the Tx flag in- 
dicates the transmitter is in the middle of a charac- 
ter, the tick counter is checked to see what transmit- 
ter operation is needed. If the counter is 28H (40D), 
all data bits plus the stop bits are complete. The 
character is therefore done and the Tx flag is reset. If 
the counter is 24H (36D), the data bits are complete 
and the next output should be a mark for the stop bit 
so a mark is loaded into the Tx pipelined data bit. 

If neither of the above conditions are met for the 
counter, the transmitter is some place in the data 
field, so the next data bit is rotated out of the Tx 
serializer into the pipelined data bit. The next tick 
outputs this bit. 

At this point the program execution is returned to 
the foreground. 

That completes the discussion of the combination 
I/O device flow charts. The UPI software listing is 
shown in Appendix Cl. Appendix C2 is example 
8085A driver software. 

Several observations concerning the drivers are ap- 
propriate. Notice that since the receiver and input 
port of the UPI use the OBF flag and interrupt out- 
put, the interrupt and flag are cleared when the mas- 
ter reads DBBOUT. This is not true for the 
transmitter. There is always some time after a mas- 
ter write of new transmitter data before the trans- 
mitter bit and pin are cleared. Thus in an interrupt- 
driven system, edge-sensitive interrupts should be 
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Figure 29E. RCV Flow Chart 



used. For polled-systems, the software must wait 
after writing new data for IBF=0 before re-examin- 
ing the Tx interrupt flag in STATUS. 

Notice that this application uses none of the user 
data memory above Register Bank 1 and only 361 
bytes of program memory. This leaves the door open 
for many improvements. Improvements that come 
to mind are increased buffering of the transmit or 
received data, modem control pins, and parallel port 
handshaking inputs. 

This completes our discussion of specific UPI appli- 
cations. Before concluding, let's look briefly at two 
debug techniques used during the development of 



these applications that you might find useful in your 
own < 



DEBUG TECHNIQUES 

Since the UPI is essentially a single-chip microcom- 
puter, the classical data, address, and control buses 
are not available to the outside world during normal 
operation. This fact normally makes debugging a 
UPI design difficult; however, certain "tricks" can be 
included in the UPI software to ease this task. 

If a UPI is handling multiple tasks, it is usually 
easier to code and debug each task individually. This 
is fairly standard procedure. Since each task usually 
utilizes only a subset of the total number of I/O pins. 
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coding only one task leaves some I/O pins free. Port 
output instructions can then be added in the task 
code being debugged which toggle these unused pins 
to determine which section of task code is being ex- 
ecuted at any particular time. The task can also be 
made to "wait" at various points by using an extra 
pin as an input and adding code to loop until a par- 
ticular input condition is met. 

One example of using an extra pin as an output is 
included in the combination serial/parallel device 
code. During initial development the receiver was 
not receiving characters correctly. Since this could 
be caused by incorrect sampling, three lines of code 
were added to toggle BIT 6 of PORT 2 at each tick of 
the sample clock. This code is at lines 184 and 185 of 
the listing. Thus by looking at the location of the tick 



sample pulse with respect to the received bit, the 
UPI sampling interval can be observed. The tick 
sample time was incorrect and the code was modi- 
fied accordingly. Similar techniques could be ap- 
plied at other locations in the program. 

The EPROM version of the UPI (8741A) also con- 
tains another feature to aid in debug: the capability 
to single step thru a program. The user may step 
thru the program instruction-by-instruction. The 
address of the next instruction to be fetched is avail- 
able on PORT 1 and the lower 2 bits of PORT 2. Fig- 
ure 30 shows the timing used in the discussion below. 
When the single step input, SS, is brought low, the 
internal processor responds by stopping during the 
fetch portion of the next instruction. This action is 
acknowledged by the processor raising the SYNC 
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output. The address of the instruction to be fetched 
is then placed on the port pins. This state may _be 
held indefinitely. To step to the next instruction, SS 
is raised high, which causes SYNC to go low, which is 
then used to return SS low. This allows the processor 
to advance to the next instruction. If SS is left high, 
the processor continues to execute at normal speed 
until SS goes low. 

To preserve port functionality, port data is valid 
while SYNC is low. Figure 31 shows the external cir- 
cuitry required to implement single step while pre- 
serving port functionality. Si is the RUN/STOP 
switch. When in the RUN position, the 7474 is held 
preset so SS is high and the UPI executes normally. 
When switched to STOP, the preset is removed and 



the next low-going transition of SYNC causes the 
7474 to clear, lowering SS. While sync is low, the 
port data is valid and the current instruction is ex- 
ecuting. Low SYNC is also used to enable the tri- 
state buffers when the ports are used as inputs. 
When execution is complete, SYNC goes high. This 
transition latches the valid port data in the 
74LS374S. SYNC going high also signifies that the 
address of the next instruction will appear on the 
port pins. This state can be held indefinitely with 
the address data displayed on the LEDs. 

When the S2 is depressed, the 7474 is set which 
causes SS to go high. This allows the processor to 
fetch and execute the instruction whose address was 
displayed. SYNC going low during execution, clears 
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the 7474 lowering SS. Thus the processor again stops 
when execution is complete and the next fetch is 
started. 

All UPI functions continue to operate while single 
stepping (the processor is actually executing NOPs 
internally while stopped). Both IBF and timer/ 
counter interrupts can be serviced. The only change 
is that the interval timer is prescaled on single 
stepped instructions and, of course, will not indicate 
the correct intervals in real time. The total number 
of instruction which would have been executed dur- 
ing a given interval is the same however. 

The single step circuitry can be used to step through 
a complete program; however, this might be a time- 
consuming job if the program is long or if only a por- 
tion is to be examined. The circuitry could easily be 
modified to incorporate the output toggling tech- 
nique to determine when to run and stop. If you 
would like to step thru a particular section of code, 



an extra port pin could replace switch Si. Extra 
instructions would then be added to lower the port 
when entering the code section and raise the port 
when exiting the section. The program would then 
stop when that section of code is reached allowing it 
to be stepped through. At the end of the section, the 
program would execute at normal speed. 

CONCLUSION 

Well, that's it. Machine readable (floppy disk or pa- 
per tape) source listings of UPI software for these 
applications are available in Insite, the Intel library 
of user-donated programs. Also available in Insite 
are the source listings for some of Intel's pre-pro- 
grammed UPI products. 

For information about Insite, write to: 
Insite 
Intel Corp. 
3065 Bowers Ave. 
Santa Clara, Ca 95051 
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:F1:ASM48 : F3: LED PRINT<:LP:) NOOBJECT 



ISIS-II MCS-48/UPI-41 MACRO ASSEMBLERi V3. 



LOG OBJ 



SOURCE STATEMENT 



1 «M0D41A 



12 
13 
14 



* UPI-41A 8-DIGIT LED DISPLAY CONTROLLER * 



i THIS PROGRAM USES THE UPI-41A AS A LED DISPLAY CONTROLLER 
i WHICH SCANS AND REFRESHES EIGHT SEVEN-SEGMENT LED DISPLAYS. 
; THE CHARACTERS ARE DEFINED BY INPUT FROM A MASTER CPU IN THE 
iFORM OF ONE EIGHT BIT WORD PER DIGIT-CHARACTER SELECTION. 



i »»*»»****»»»»»*«*»*#»#»*•«•»*#»«#*»»»*»»««»«*»«»*•»#»««»•»»#««»«*»#*»♦»«« 



i REGISTER DEFINITIONS: 
REGISTER 



RBI 



RBO 



21 
22 
23 



26 
27 



R4 
R5 
R6 



DISPLAY MAP POINTER NOT USED 

NOT USED NOT USED 
DATA WORD AND CHARACTER STORAGE NOT USED 

DIGIT COUNTER NOT USED 

NOT USED NOT USED 

NOT USED NOT USED 

NOT USED NOT USED 

ACCUMULATOR STORAGE NOT USED 



J *«»«««««««««*«««««»»«*«««««»»«*««««««««««««««»«««««««««•«««««#«««')('«*')(''«'« 



30 
31 
32 
33 
34 
35 



PORT PIN DEFINITIONS: 
PIN 



PORT 1 FUNCTION PORT 2 FUNCTION 

SEGMENT DRIVER CONTROL DIGIT DRIVER CONTROL 
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ISIS-II MCS-48/UPI-41 MACRO ASSEMBLERi V3. 



LOG OBJ 



SOURCE STATEMENT 



i DISPLAY DATA WORD BIT DEFINITION: 



38 
39 



0-4 
5-7 



CHARACTER SELECT 
DIGIT SELECT 



43 i CHARACTER SELECT 

44 ; 



D4 D3 D2 Dl DO CHARACTER 



34 i 
53 i 
56 



62 
63 



69 
70 



76 i 

77 i 

78 ; 

79 i 

80 ; 

81 i 

82 i 

83 ; 

84 ; 



DIGIT SELECT: 



D5 



1 

O 

1 





DIGIT NUMBER 
1 
2 
3 
4 



86 i 110 7 

87 ; 111 8 

88 > *«««««««««»«#««««««««*«««»«««««**««««««««*«««««««**«*«««««»«««««««**««« 

89 *EJECT 
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ISIS-II MCS-4B/UPI-41 MACRO ASSEMBLER, V3. O 



SOURCE STATEMENT 



0000 
0000 0409 

0002 00 

0003 0436 

0005 00 

0006 00 

0007 04 ID 



0007 DS 
OOOA 8A08 
OOOC B838 
OOOE 23FF 

0010 AO 

0011 18 

0012 F8 

0013 B20E 
0015 BBOO 
0017 23F1 
0019 62 
OOIA 55 
OOIB 25 
OOIC 05 



91 
92 
93 
94 
95 
96 
97 
98 
99 
100 
101 
102 
103 
104 
105 
106 
107 
108 
109 
110 
ill 
112 
113 
114 
115 
116 
117 
118 
119 
120 
121 
122 
123 
124 
125 
126 
127 
128 
129 
130 
131 
132 
133 
134 
135 
136 
137 



i EQUATES 

>THE FOLLOWING CODE DESIGNATES "TIME" AS A VARIABLE. THIS 

J ADJUSTS THE AMOUNT OF CYCLES THE TIMER COUNTS BEFORE 

I A TIMER INTERRUPT OCCURS AND REFRESHES THE DISPLAY. APPROXIMATELY 

i 50 TIMES PER SECOND. 

TIME EQU -OFH i TIMER VALUE 2. 5MSEC 

J *««♦««««#♦#*«♦»♦♦««■»»♦«♦***«♦♦««««»#♦»»«»»##♦♦»««♦«♦♦*«♦•»♦«««»*•»««♦«♦♦♦» 

i INTERRUPT BRANCHING 

J THIS PORTION OF MEMORY IS DEDICATED FOR USE OF RESET AND 

i INTERRUPT BRANCHING. WHEN THE INTERRUPTS ARE ENABLED THE 

iCODE AT THE FOLLOWING DESIGNATED SPOTS ARE EXECUTED WHEN A 

; RESET OR A INTERRUPT OCCURS. 

ORG i 

JMP START i RESET 

NOP 

JMP INPUT i IBF INTERRUPT 

NOP i 

NOP 

JMP DISPLA i TIMER INTERRUPT 

i ««»#»«««**«»«««*«*»«««««««««**«»«»»»«««*«*««*«««*«««««*«««»«««*««»«*«*««» 
i INITIALIZATION 

J THE FOLLOWING CODE SETS UP THE UP I -41 AND DISPLAY HARDWARE 
J INTO OPERATIONAL FORMAT. THE DISPLAY IS TURNED OFF, THE DISPLAY 
iMAP IS FILLED WITH "BLANK" CHARACTERS, THE TIMER SET AND THE 
i INTERRUPTS ARE ENABLED. 



START: 



SEL 
ORL 
MOV 
BLKMAP: MOV 
MOV 
INC 
MOV 
JB5 
MOV 
MOV 
MOV 
STRT 



RBI 

P2, #08H 
RO, #38H 
A, #OFFH 
SRO, A 
RO 

A, RO 
BLKMAP 
R3, #00H 
A, #TIME 
T, A 
T 
TCNTI 



iTURN DIGIT DRIVERS OFF 

i DISPLAY MAP POINTER, BOTTOM OF DISPLAY MAP 
J FF=" BLANK" 
J BLANK TO DISPLAY MAP 
i INCREMENT DISPLAY MAP POINTER 
i DISPLAY MAP POINTER TO ACCUMULATOR 
J BLANK DISPLAY MAP TILL FILLED 
iSET DIGIT COUNTER TO 
i TIMER VALUE 
J LOAD TIMER 
; START TIMER 
i ENABLE TIMER INTERRUPT 
EN I i ENABLE IBF INTERRUPT 

J ♦♦♦♦♦♦*«»»'»»«»»»»*»»«»*»»»»»*»«*»»»*#»»»'»«*#««»»»*»»««»#»«»*«**»»*^ 

i USER PROGRAM 

iA USERS PROGRAM WOULD INITIALIZE AT THIS POINT. THE FOLLOWING 

iCODE IS UND CONCLUDED WITH 

iSYNC CHARACTERS (OAAH). A CHECKSUM BYTE IMMEDIATELY PRECEEDS THE 

i FINAL SYNC. WHEN READING. THE CONTROLLE************************************* 

♦EJECT 
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SOURCE STATEMENT 



OOID 03 
OOIE AF 
00 IF 8A08 

0021 FB 

0022 4338 
0024 AS 

0023 FO 

0026 39 

0027 FB 

0028 3A 

0029 IB 
002A D307 
002C 9630 
002E BBOO 

0030 23F1 

0032 62 

0033 39 

0034 FF 
0033 93 



138 
139 
140 
141 
142 
143 



146 
147 
148 
149 
130 
131 
152 
133 
134 
133 
136 
137 
138 
139 
160 
161 
162 
163 
164 
163 
166 
167 
168 



i DISPLAY ROUTINE 

i THIS PORTION OF THIS PROGRAM IS AN INTERRUPT ROUTINE WHICH IS 

; ACTED UPON WHEN THE TIMER COUNT IS COMPLETED. THE ROUTINE UPDATES 

;ONE DISPLAY DIGIT FROM THE DISPLAY MAP PER INTERRUPT SEQUENTIALLY. 

iTHUS EIGHT TIMER INTERRUPTS WILL HAVE REFRESHED THE ENTIRE DISPLAY. 

i REGISTER BANK 1 IS SELECTED AND THE ACCUMULATOR IS SAVED UPON 

i ENTERING THE ROUTINE. ONCE THE DISPLAY HAS BEEN REFRESHED THE TIMER 

; IS RESET AND THE ACCUMULATOR AND PRE-INTERRUPT REGISTER BANK IS RESTORED. 

i 



DISPLA. SEL RBI J REGISTER BANK 1 

<SAVE ACCUMULATOR 
jTURN DIGIT DRIVERS OFF 
J DIGIT COUNTER TO ACCUMULATOR 
i "OR" TO GET DISPLAY MAP ADDRESS 
i DISPLAY MAP POINTER 
J GET CHARACTER FROM DISPLAY MAP 
i OUTPUT CHARACTER TO SEGMENT DRIVERS 
} DIGIT COUNTER VALUE TO ACCUMULATOR 
i OUTPUT TO DIGIT DRIVERS 
J INCREMENT DIGIT COUNTER 
i CHECK IF AT LAST DIGIT 
» RESET TIMER IN NOT LAST DIGIT 
J RESET DIGIT COUNTER 

SET I ME: MOV A. #TIME J TIMER VALUE 

i LOAD TIMER 
i START TIMER 
i RESTORE ACCUMULATOR 
i RETURN 

j «»«♦♦«»»«»«♦»»»«#»«♦«•«■#«♦»*«»»♦#««»»♦♦*♦»»«♦»♦*««»*♦#«#♦»«»♦«»«*#**«»♦ 

♦EJECT 



SEL 

MOV 

ORL 

MOV 

ORL 

MOV 

MOV 

OUTL 

MOV 

OUTL 

INC 

XRL 

JNZ 

MOV 

MOV 

MOV 

STRT 

MOV 

RETR 



RBI 
R7, A 
P2, #08H 
A. R3 
A, #38H 
RO. A 
A, (SRO 
PI, A 
A, R3 
P2, A 
R3 

A, #07H 
SET I ME 
R3. «00H 
A. #TIME 



A, R7 
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SOURCE STATEMENT 



0036 DS 

0037 AF 
003B 22 

0039 AA 
003A 47 
003B 77 
003C 5307 
003E 4338 

0040 AS 

0041 FA 

0042 93 IF 

0044 E3 

0045 AA 

0046 D37F 
0048 C64E 
004A FA 
004B AO 
004C 04 SI 
004E FA 
004F 50 

0050 AO 

0051 FF 

0052 93 



169 
170 
171 
172 
173 
174 
175 
176 
177 
178 
179 
180 
181 
182 
183 
184 
185 
186 
187 
188 
189 
190 
191 
192 
193 
194 
195 
196 
197 
198 
199 
200 
201 
202 
203 
204 
205 
206 
207 



; INPUT CHARACTER AND DIGIT ROUTINE 

i THIS PORTION OF THE PROGRAM IS AN INTERRUPT ROUTINE WHICH 

i IS ACTED UPON WHEN THE IBF BIT IS SET. THE ROUTINE GETS THE 

> DISPLAY DATA WORD FROM THE DBB AND DEFINES BOTH THE DIGIT AND 

iTHE CHARACTER TO BE DISPLAYED. THIS IS DONE BY MEANS OF A 

i CHARACTER LOOP-UP TABLE AND A DISPLAY MAP FOR DIGIT AND CHARACTER 

{LOCATION. SPECIAL CONSIDERATION IS TAKEN FOR A DECIMAL POINT WHICH IS 

i SIMPLY ADDED TO THE EXISTING CHARACTER IN THE DISPLAY MAP. REGISTER 

iBANK 1 IS SELECTED AND THE ACCUMULATOR IS SAVED UPON ENTERING 

iTHE ROUTINE. ONCE THE DATA WORD HAS BEEN FULLY DEFINED THE ACCUMULATOR 

iAND THE PRE-INTERRUPT REGISTER BANK IS RESTORED. 



INPUT: 



SEL 

MOV 

IN 

MOV 

SWAP 

RR 

ANL 

ORL 

MOV 

MOV 

ANL 

M0VP3 

MOV 

XRL 

JZ 

MOV 

MOV 



RBI 
R7, A 
A, DBB 
R2. A 



A, #07H 
Ai *38H 
RO. A 
A«R2 
A, #1FH 
A. SA 
R2« A 
A. #7FH 
DPOINT 
A, R2 
eRO. A 
RETURN 
A, R2 
A. SRO 
eRO> A 
A, R7 



{REGISTER BANK 1 

iSAVE ACCUMULATOR 

iGET DATA 

iSAVE DATA WORD 

J DEFINE DIGIT LOCATION 



> DIGIT LOCATION IN DIGIT POINTER 

} SAVED DATA WORD TO ACCUMULATOR 

J DEFINE CHARACTER LOOK-UP-TABLE LOC. 

J GET CHARACTER 

iSAVE CHARACTER 

i IS CHARACTER DECIMAL POINT 

i 

J SAVED CHARACTER TO ACCUMULATOR 

J CHARACTER TO DISPLAY MAP 



DPOINT: MOV 

ANL 

MOV 
RETURN: MOV 

RETR 
i ##««♦»»««»#»*««*«««««»«««»»«♦«»«««»««»««»♦»«««♦»«»*«««*»««»««*«♦«»*»»* 
♦EJECT 



J SAVED CHARACTER TO ACCUMULATOR 
> "AND" WITH OLD CHARACTER 
iBACK TO DISPLAY MAP 
{RESTORE ACCUMULATOR 
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LINE 



SOURCE STATEMENT 



0300 

0300 CO 

0301 F9 

0302 A4 

0303 BO 

0304 99 
0309 92 

0306 82 

0307 F8 

0308 80 

0309 98 
030A 88 
030B 83 
030C C6 
030D Al 
030E 86 
030F 8E 

0310 7F 

0311 C2 

0312 89 

0313 FB 

0314 El 
0313 C7 

0316 AB 

0317 A3 

0318 8C 

0319 AF 
031A 87 
031B CI 
031C 91 
031D BF 
031E FD 
031F FF 



208 
209 
210 
211 
212 
213 
214 
219 
216 
217 
218 
219 
220 
221 
222 
223 
224 
229 
226 
227 
228 
229 
230 
231 
232 
233 
234 
239 
236 
237 
238 
239 
240 
241 
242 
243 
244 
249 
246 
247 
248 
249 
290 
291 



i LOOK-UP TABLE 

} THIS LOOK-UP TABLE ORIGINATES IN PAOE 3 OF THE UPI-41 PROGRAM 

J MEMORY. IT IS USED TO DEFINE THE CORRECT LEVEL OF EACH SEGMENT 

J AND DECIMAL POINT FOR A SELECTED CHARACTER FROM THE INPUT ROUTINE. 

i INVERSE LOGIC IS USED BECAUSE OF THE SPECIFIC DRIVER CIRCUITRY. THUS 

J A 1 ON A GIVEN SEGMENT MEANS IT IS OFF AND A MEANS IT IS ON. 



DB 
DB 
DB 
DB 
DB 
DB 
DB 
DB 
OB 
DB 



DB 
DB 
DB 
DB 
DB 
DB 



DB 
DB 
DB 
DB 
DB 



300H 

OCOH 

0F9H 

0A4H 

OBOH 

99H 

92H 

82H 

0F8H 

80H 

98H 

88H 

83H 

0C6H 

OAIH 

86H 

8EH 

7FH 

0C2H 

89H 

OFBH 

OEIH 

0C7H 

OABH 

0A3H 

8CH 

OAFH 

87H 

OCIH 

91H 

OBFH 

OFDH 

OFFH 



»#*««««SEOMENTS'K'-M"H-'»*'M"»* 



ORG 
CHO: DB 
CHI: 
CH2: 
CH3: 
CH4: 
CH9: 
CH6: 
CH7: 
CHS: 
CH9: 
CHA: 
CHB: 
CHC: 
CHD: 
CHE: 
CHF: 
CHOP: 
CHG: 
CHH: 
CHI: 
CHJ: 
CHL: 
CHN: 
CHO: 
CHP: 
CHR: 
CHT: 
CHU: 
CHY: 

CHD ASH: DB 
CHAPOS: DB 
BLANK: DB 

END 



1 1 




















1 1 


1 


1 


1 








1 


1 


1 








1 








1 


1 


1 














1 





1 


1 








1 


1 





1 








1 





1 














1 





1 1 


1 


1 


1 











1 




















1 





1 


1 











1 








1 











1 
















1 


1 1 











1 







1 


1 













1 


1 











1 







1 








1 


1 







1 


1 


1 


1 


1 




1 


1 1 



















1 








1 







1 


1 1 


1 


1 


1 







1 


1 1 


1 













1 


1 1 











1 




1 


1 


1 





1 







1 


1 


1 













1 


1 








1 


1 







1 


1 





1 


1 




1 


1 











1 




1 


1 1 

















1 


1 





1 










1 


1 


1 


1 


1 


1 




1 


1 1 


1 


1 


1 


1 





1 


1 1 


1 


1 


1 


1 




1 



USER SYMBOLS 

BLANK 03 IF BLKM 

CH6 0306 CH7 

CHD 030D CHDA 

CHJ 0314 CHL 

CHY 031C DISP 

ASSEMBLY COMPLETE, 



OOOE 


CHO 


0300 


CHI 


0301 


CH2 


0302 


CH3 


0303 


CH4 


0304 


CHS 


0305 


0307 


CHS 


0308 


CH9 


0309 


CHA 


030A 


CHAPOS 


031E 


CHB 


030D 


CHC 


030C 


031D 


CHOP 


0310 


CHE 


030E 


CHF 


030F 


CHG 


0311 


CHH 


0312 


CHI 


0313 


0319 


CHN 


0316 


CHO 


0317 


CHP 


0318 


CHR 


0319 


CHT 


031A 


CHU 


031B 


OOID 


DPOINT 


004E 


INPUT 


0036 


RETURN 


0091 


SET I ME 


0030 


START 


0009 


TIME 


FFFl 


JO ERRORS 
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INE SOURCE STATEMENT 

1 ♦M0D41A 

2 i »««««««««««««««»««**«««««««««««««««*'»«»**««««« 

3 i « UP I -41 A SENSOR MATRIX CONTROLLER « 

4 i »♦**♦»#*»««««♦«#♦#«♦#*«♦«♦««#»««««♦♦«««»♦#»»#* 

5 i 

6 i THIS PROGRAM USES THE UP I -41 A AS A SENSOR MATRIX CONTROLLER. 

7 i IT HAS MONITORING CAPABILITIES OF UP TO 128 SENSORS. THE COORDINATE 

8 ;AND SENSOR STATUS OF EACH DETECTED CHANGE IS AVAILABLE TO THE MASTER 

9 i MICROPROCESSOR IN A SINGLE BYTE. A 40X8 FIFO QUEUE IS PROVIDED FOR 

10 iDATA BUFFERING. BOTH HARDWARE OR POLLED INTERRUPT METHODS CAN BE USED 

11 iTO NOTIFY THE MASTER OF A DETECTED SENSOR CHANGE. 

12 i 

13 i «*♦««♦#♦»«♦♦#»»««#♦«♦»♦*♦»»#*#*««»♦«*»♦«««*»**«»♦*««■»«»♦*«««*»#♦«»««♦♦» 



14 










19 


i REGISTER 


DEFINITIONS. 




16 




REGISTER RBQ 


RBI 


17 
18 














RO MATRIX MAP POINTER 


NOT USED 


19 






Rl FIFO POINTER 


NOT USED 


20 






R2 SCAN ROW SELECT 


NOT USED 


21 






R3 COLUMN COUNTER 


NOT USED 


22 






R4 FIFO-IN 


NOT USED 


23 






R9 FIFO-OUT 


NOT USED 


24 






R6 CHANGE WORD 


NOT USED 


29 






R7 COMPARE 


NOT USED 


26 










27 




28 










29 


;PORT 


PIN 


DEFINITIONS: 




30 






N 




31 
32 
33 


jPIN 




PORT 1 FUNCTION PIN 


PORT 2 FUNCTION 


iPO-7 




COLUMN LINE INPUTS PO-3 


ROW SELECT OUTPUTS 


34 






P4 


FIFO NOT EMPTY INTERRUPT 


39 






P9 


DBF INTERRUPT 


36 






P6-7 


NOT USED 


37 










38 




39 










40 


♦EJECT 
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PAGE 



41 
42 
43 
44 
43 
46 



SOURCE STATEMENT 

•#♦»««**#»»»»»#*»»»»«#»»»»♦»«♦»»«♦♦«»»»♦»»♦♦»«»««»«»«♦»«»♦»»»*»» 
; CHANGE WORD BIT DEFINITION: 

BIT FUNCTION 



DO-6 
07 



SENSOR COORDINATE 
SENSOR STATUS 



OOOF 
0008 
002F 



30 
31 
52 
33 
34 
53 
56 
37 
38 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
78 



♦*«#♦*«»#»»♦«< 

STATUS REGISTER BIT DEFINITION: 

BIT 

DO 

Dl-3 
D4 
D5-7 



»»♦«♦*#*«»« 



»*««**« 



FUNCTION 

DBF 

IBF, FO, Fl (NOT USED) 

FIFO NOT EMPTY 

USED DEFINED (NOT USED) 



EQUATES 

THE FOLLOWING CODE DESIGNATES THREE VARIABLES; SCANTM, FIFOBA 
AND FIFOTA. SCANTM ADJUSTS THE LENGTH OF A DELAY BETWEEN 
SCANNING SWITCH. THIS SIMULATES DEBOUNCE FUNCTIONS. FIFOBA 
IS THE BOTTOM ADDRESS OF THE FIFO. FIFOTA IS THE TOP ADDRESS 
OF THE FIFO. THIS MAKES IT POSSIBLE TO HAVE A FIFO 3 TO 40 
BYTES IN LENGTH. 

«»♦♦»♦»»«««#»»««♦«♦»»«♦»«♦#♦«««♦♦♦♦»♦♦»«•»««♦#««♦«♦♦«»»♦*»»«♦«♦*«»*««* 



SCANTM EQU 
FIFOBA EQU 
FIFOTA EQU 



OFH 
08H 
2FH 



i SCAN TIME ADJUST 
iFIFO BOTTOM ADDRESS 
i FIFO TOP ADDRESS 
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SOURCE STATEMENT 



79 
80 
81 
82 



85 
86 
87 
88 
89 
90 
91 



»»«♦•»■♦»»««» 



h»»»#»»««««»**««««» 



i INITIALIZATION 

i THE PROGRAM STARTS AT THE FOLLOWING CODE UPON RESET. WITHIN 
;THIS INITIALIZATION SECTION THE REGISTERS THAT MAINTAIN THE MATRIX 
i MAP, FIFO AND ROW SCANNING ARE SET UP. PORT 1 IS SET HIGH FOR USE 
i AS AN INPUT PORT FOR THE COLUMN STATUS. BIT 4 OF STATUS REGISTER IS 
(WRITTEN TO CONVEY A FIFO EMPTY CONDITION. THE INITIAL COLUMN STATUS 
i OF ALL THE ROWS IN THE SENSOR MATRIX IS THEN READ INTO THE MATRIX 
iMAP. ONCE THE MATRIX MAP IS FILLED THE OBF INTERRUPT (PORT 2-4) IS 
i ENABLED. 

; «♦«♦«««#««««♦♦♦«»«»■»•««♦««»*«»«»««♦♦#«»»♦«♦»»««♦»«* «**»♦♦«•«■*»♦« «♦»«««« 



0000 

0000 B83F 
0002 BAOF 
0004 BC08 
0006 BD2F 
0008 e9FF 
OOOA 2300 
OOOC 90 
OOOD FA 
OOOE 3A 
OOOF 09 

0010 AO 

0011 FA 

0012 C610 

0014 C8 

0015 CA 

0016 040D 
0018 DAIO 
001 A FA 
00 IB 3A 
OOIC F5 



94 




ORG 





95 


INITMX: 


MOV 


RO. #3FH 


96 




MOV 


R2, #OFH 


97 




MOV 


R4, #FIFOBA 


98 




MOV 


R5, #FIFOTA 


99 




ORL 


PI, #OFFH 


100 




MOV 


A, #00H 


101 




MOV 


STS, A 


102 


FILLMX; 


MOV 


A, R2 


103 




OUTL 


P2, A 


104 




IN 


A, PI 


105 




MOV 


eRO, A 


106 




MOV 


A, R2 


107 




JZ 


OBFINT 


108 




DEC 


RO 


109 




DEC 


R2 


110 




JMP 


FILLMX 


111 


OBFINT: 


MOV 


R2, #10H 


112 




MOV 


A, R2 


113 




OUTL 


P2, A 


114 




EN 


FLAGS 


115 








116 


♦EJECT 







MATRIX MAP POINTER REGISTER, TOP ADDRESS 

SCAN ROW SELECT REGISTER, TOP ROW 

FIFO INPUT ADDRESS REGISTER, BOTTOM OF FIFO 

FIFO OUTPUT ADDRESS REGISTER, TOP OF FIFO 

INITIALIZE PORT 1 HIGH FOR INPUTS 

INITIALIZE STATUS REGISTER, FIFO EMPTY 

WRITE TO STATUS REGISTER, BITS 4-7 

SCAN ROW SELECT TO ACCUMULATOR 

OUTPUT SCAN ROW SELECT TO PORT 2 

INPUT COLUMN STATUS PORT 1 

LOAD MATRIX MAP WITH COLUMN STATUS 

CHECK SCAN ROW SELECT REGISTER VALUE FOR 

IF ENABLE OBF INTERRUPT 

DECREMENT TO NEXT MATRIX MAP ADDRESS 

DECREMENT TO SCAN NEXT ROW 

FILL NEXT MATRIX MAP ADDRESS 

BIT 4 HIGH IN ROW SCAN SELECT REGISTER 

ROW SCAN SELECT VALUE TO ACCUMULATOR 

INITIALIZE PORT 2, BIT 4 FOR "EN FLAGS" 

ENABLE OBF INTERRUPT PORT 2, BIT 4 
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LOG OBJ 



SOURCE STATEMENT 



OOID FA 
00 IE 330F 
0020 C626 

0022 C8 

0023 CA 

0024 042C 
0026 B83F 

0028 FA 

0029 430F 
002B AA 
002C FA 
002D 3A 
002E BBOF 

0030 EB30 

0032 09 

0033 20 

0034 DO 

0035 AF 

0036 C669 



118 
119 
120 
121 
122 
123 
124 
125 
126 
127 
128 
129 
130 
131 
132 
133 
134 
135 
136 
137 
138 
139 
140 
141 
142 
143 
144 
145 
146 
147 
148 
149 
150 
151 
152 
153 
154 
155 
156 
157 
158 



SCAN AND COMPARE 

THE FOLLOWING CODE IS THE SCAN AND COMPARE SECTION OF THE PROGRAM. 
UPON ENTERING THIS SECTION A CHECK IS MADE TO SEE IF THE ENTIRE MATRIX 
HAS BEEN SCANNED. IF SO THE REGISTERS THAT MAINTAIN THE MATRIX MAP AND ROW 
SCANNING ARE RESET TO THE BEGINNING OF THE SENSOR MATRIX. IF THE ENTIRE 
MATRIX HASNT BEEN SCANNED THE REGISTERS INCREMENT TO SCAN THE NEXT ROW. 
FROM THIS POINT ON THE ROW SCAN SELECT REGISTER IS USED FOR TWO FUNCTIONS. 
BITS 0-3 FOR SCANNING AND BITS 4 AND S FOR THE EXTERNAL INTERRUPTS. THUSLY 
ALL USAGE OF THE REGISTERS IS DONE BY LOGICALLY MASKING IT SO AS TO ONLY 
AFFECT THE FUNCTION DESIRED. ONCE THE REGISTERS ARE RESET. ONE ROW OF THE 
SENSOR MATRIX IS SCANNED. A DELAY IS EXECUTED TO ADJUST FOR SCAN TIME 
(DEBOUNCE). A BYTE OF COLUMN STATUS IS THEN READ INTO THE MATRIX MAP. 
AT THE TIME THE NEW COLUMN STATUS IS COMPARED TO THE OLD. THE RESULT IS 
STORED IN THE COMPARE REGISTER. THE PROGRAM IS THEN ROUTED ACCORDING TO 
WHETHER OR NOT A CHANGE WAS DETECTED. 



****** »***»**««'«*«'#»* **««-» 



MOV 

ANL 

JZ 

DEC 

DEC 

JMP 

MOV 

MOV 

ORL 

MOV 

MOV 

OUTL 

MOV 

DJNZ 

IN 

XCH 

XRL 

MOV 

JZ 



A, R2 

A. #OFH 

RSETRO 

RO 

R2 

SCANMX 

RO, #3FH 

A, R2 

A, #OFH 

R2, A 

A, R2 

P2, A 

R3, tSCANTM 

R3, DELAY2 

A, PI 

A, eRO 

A, CRO 

R7, A 

CHFFUL 



i SCAN ROW SELECT TO ACCUMULATOR 

i CHECK FOR SCAN VALUE ONLY, NOT INTERRUPT 

i IF RESET REGISTERS 

i DECREMENT MATRIX MAP POINTER 

; DECREMENT SCAN ROW SELECT 

i SCAN MATRIX 

; RESET MATRIX MAP POINTER REGISTER. TOP ADDRESS 

i SCAN ROW SELECT TO ACCUMULATOR 

; RESET SCAN ROW SELECT, NO INTERRUPT CHANGE 

;SCAN ROW SELECT REGISTER 

i SCAN ROW SELECT TO ACCUMULATOR 

i OUTPUT SCAN ROW SELECT TO PORT 2 

iSET DELAY FOR OUTPUT SCAN TIME 

; DELAY 

; INPUT COLUMN STATUS FROM PORT 1 TO ACCUMULATOR 

; STORE NEW COLUMN STATUS SAVE OLD IN ACCUMULATOR 

; COMPARE OLD WITH NEW COLUMN STATUS 

; SAVE COMPARE RESULT IN COMPARE REGISTER 

; IF THE SAME, CHECK IF FIFO IS FULL 
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SOURCE STATEMENT 



0038 BB08 
003A CB 
003B FO 
003C 77 
003D AO 
003E FF 
003F 77 

0040 AF 

0041 F243 
0043 0469 

0045 FA 

0046 330F 

0048 E7 

0049 E7 
004A E7 
004B 4B 

004C AE 
004D FO 
004E 5380 

0050 4E 

0051 AE 



159 
160 
161 
162 
163 
164 
165 
166 
167 
168 
169 
170 
171 
172 
173 
174 
175 
176 
177 
178 
179 
180 
181 
182 
183 
184 
185 
186 
187 
188 
189 
190 
191 
192 
193 
194 
195 
196 
197 
198 
199 



CHANGE MORD ENCODING 

i THE FOLLOWING CODE IS THE CHANGE WORD ENCODING SECTION. THIS 

; SECTION IS ONLY EXECUTED IF A CHANGE WAS DETECTED. THE COLUMN COUNTER 

i IS SET AND DECREMENTED TO DESIGNATE EACH OF THE 8 COLUMNS. THE COMPARE 

(REGISTER IS LOOKED AT ONE BIT AT A TIME TO FIND THE EXACT LOCATION OF 

(THE CHANGE(S). WHEN A CHANGE IS FOUND IT IS ENCODED BY GIVING IT A 

(COORDINATE FOR ITS LOCATION. THIS IS DONE BY COMBINING THE PRESENT VALUE 

i IN THE ROW SCAN SELECT REGISTER AND THE COLUMN COUNTER. THE ACTUAL STATUS 

I OF THAT SENSOR IS ESTABLISHED BY LOOKING AT THE CORRESPONDING BYTE IN 

I THE MATRIX MAP. THIS STATUS IS COMBINED WITH THE COORDINATE TO ESTABLISH 

i THE CHANGE WORD. THE CHANGE WORD IS THEN STORED IN THE CHANGE WORD REGISTER 



MOV 
RRLOOK: DEC 
MOV 
RR 
MOV 
MOV 
RR 
MOV 
JB7 
JMP 
ENCODE. MOV 
ANL 
RL 
RL 
RL 
ORL 

MOV 
MOV 
ANL 
ORL 
MOV 



R3. #08H 

R3 

A, ®R0 

A 

(SRO, A 

A, R7 

A 

R7, A 

ENCODE 

CHFFUL 

A, R2 

A, #OFH 

A 



»»»♦♦♦»»♦««»♦#♦♦»♦♦#♦♦»♦♦♦««##»«»#♦♦« 



!-»**«« 



R6, A 
A, SRO 
A, #80H 



; SET COLUMN COUNTER REGISTER TO 8 

i DECREMENT COLUMN COUNTER 

i COLUMN STATUS TO ACCUMULATOR 

; ROTATE COLUMN STATUS RIGHT 

i ROTATED COLUMN STATUS BACK TO MATRIX MAP 

; COMPARE REGISTER VALUE TO ACCUMULATOR 

; ROTATE COMPARE VALUE RIGHT 

(ROTATED COMPARE VALUE TO COMPARE REGISTER 

, TEST BIT 7 IF CHANGE DETECTED ENCODE CHANGE WORD 

i IF NO CHANGE IS DETECTED CHECK FOR FIFO FULL 

; SCAN ROW SELECT TO ACCUMULATOR OOOOXXXX 

i ROTATE ONLY SCAN VALUE 

i ROTATE LEFT OOOXXXXO 

i ROTATE LEFT OOXXXXOO 

i ROTATE LEFT OXXXXOOO 

; ESTABLISH MATRIX COORDINANT OXXXXXXX 

i (OR) COLUMN COUNTER VALUE WITH ACCUMULATOR 

i SAVE COORDINANT IN CHANGE WORD REGISTER 

i COLUMN STATUS FROM MATRIX MAP TO ACCUMULATOR 

; ALL BITS BUT BIT 7 

; <0R) SENSOR STATUS WITH COORDINATE FOR COMPLETED CHANGE WORD 

i SAVE CHANGE WORD XXXXXXXX 
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LINE 



SOURCE STATEMENT 



0052 FC 

0053 A9 

0054 FE 

0055 Al 

0056 2310 

0058 90 

0059 8A20 
005B FA 
005C 4320 
005E AA 
005F 232F 

0061 DC 

0062 C667 

0064 IC 

0065 0469 
0067 BC08 
0069 FC 
006A DD 
006B 967D 
006D 866D 
006F 232F 

0071 DD 

0072 C677 

0074 ID 

0075 0479 
0077 BD08 

0079 FD 
007A A9 
007B Fl 
007C 02 
007D FB 
007E 963A 

0080 2308 



200 
201 
202 
203 
204 
205 
206 
207 
208 
209 
210 
211 
212 
213 
214 
215 
216 
217 
218 
219 
220 
221 
222 
223 
224 
225 
226 
227 
228 
229 
230 
231 
232 
233 
234 
235 
236 
237 
238 
239 
240 
241 
242 
243 
244 
245 
246 
247 
248 
249 
250 
251 



; ♦»#«»»*♦»♦»»««♦»»«♦»«»♦»»♦«♦♦»*♦#♦»»»»»»»»*»»♦»♦»♦«»♦*♦«♦♦♦«♦»»♦»#»«» 

; FIFO-DBBOUT MANAGEMENT 

i THE FOLLOWING CODE IS THE FIFO-DBBOUT MANAGEMENT SECTION OF THE 

i PROGRAM. THIS SECTION TAKES AN ENCODED CHANGE WORD AND LOADS IT INTO 

i THE FIFO. THE FIFO NOT EMPTY INTERRUPT IS THEN SET AND THE FIFO-IN 

i POINTER GETS UPDATED. A FIFO FULL CONDITION IS THEN CHECKED FOR AND 

; ROUTED ACCORDINGLY. IF BOTH THE FIFO AND OBF HAVE CHANGE WORDS THE 

; PROGRAM LOCKS UP UNTIL THIS HAS CHANGED. IF THE FIFO ISNT FULL COLUMN 

; COUNTER- O, FIFO EMPTY AND OBF CONDITIONS ARE CHECKED. THE FIFO-OUT 

i POINTER IS SET AND DBBOUT IS LOADED IF THE FIFO ISNT EMPTY AND OBF ISNT 

iSET. IF THIS ISNT THE SITUATION, PROGRAM FLOW IS ROUTED BACK TO THE 

i THE SCAN AND COMPARE SECTION TO SCAN THE NEXT ROW. 

i »#»»«♦«»»#»##««»♦«#»#««#»♦««»»♦♦♦*«♦#»#♦♦*«♦*»♦«»♦«#»♦«#♦«»♦♦♦♦•»♦»«»« 

LOADFF: MOV A, R4 i FIFO INPUT ADDRESS TO ACCUMULATOR 

MOV R1,A iFIFO POINTER USED FOR INPUT 

MOV A. R6 i CHANGE WORD TO ACCUMULATOR 

MOV SRI. A ;LOAD FIFO AT FIFO INPUT ADDRESS 

STATNE: MOV A, #10H iBIT 4 FOR FIFO NOT EMPTY 

MOV STS, A i WRITE TO STATUS REGISTER, FIFO NOT EMPTY 

INTRHl: ORL P2, #20H iFIFO NOT EMPTY INTERRUPT PORT 2-5 HIGH 

MOV A, R2 i ROW SCAN SELECT TO ACCUMULATOR 

ORL A, #20H i SAVE INTERRUPT, NO CHANGE TO SCAN VALUE 

MOV R2, A ;ROW SCAN SELECT REGISTER 

ADJFIN: MOV A. #FIFOTA ; FIFO TOP ADDRESS TO ACCUMULATOR 

XRL A, R4 i COMPARE WITH CURRENT FIFO INPUT ADDRESS 

JZ RSFFIN i IF THE SAME RESET FIFO INPUT REGISTER 

INC R4 iNEXT FIFO INPUT ADDRESS 

JMP CHFFUL ; CHECK FIFO FULL 

RSFFIN: MOV R4, #FIFOBA ; RESET FIFO INPUT REGISTER, BOTTOM OF FIFO 

CHFFUL: MOV A, R4 ; FIFO INPUT ADDRESS TO ACCUMULATOR 

XRL A, R5 (COMPARE INPUT WITH OUTPUT FIFO ADDRESS 

JNZ CHCNTR , IF NOT SAME CHECK COLUMN COUNTER VALUE 

CHOBFl: JOBF CHOBFl ; IF OBF IS 1 THEN CHECK OBF 

ADJFOT: MOV A, #FIFOTA iFIFO TOP ADDRESS TO ACCUMULATOR 

XRL A, R5 1 COMPARE TOP TO OUTPUT FIFO ADDRESS 

JZ RSFFOT i IF THE SAME RESET FIFO OUTPUT REGISTER 

INC R5 iNEXT FIFO OUTPUT ADDRESS 

JMP LOADDB i LOAD DBBOUT 

RSFFOT: MOV R5, #FIFOBA i RESET FIFO OUTPUT ADDRESS TO BOTTOM OF FIFO 

LOADDB: MOV A, R5 i OUTPUT FIFO ADDRESS TO ACCUMULATOR 

MOV R1,A iFIFO POINTER USED FOR OUTPUT 

MOV A, eRl ; CHANGE WORD TO ACCUMULATOR 

OUT DBB,A i CHANGE WORD TO DBBOUT 

CHCNTR: MOV A, R3 i COLUMN COUNTER TO ACCUMULATOR 

JNZ RRLOOK i IF NOT FINISH CHANGE WORD ENCODING 

CHFFEM: MOV A, #FIFOBA iFIFO BOTTOM ADDRESS TO ACCUMULATOR 

♦EJECT 
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SOURCE STATEMENT 



0082 


DC 




252 




XRL 


A, R4 




COMPARE FIFO INPUT ADDRESS WITH 


FIFO BOTTOM ADD 






0083 


C68C 




233 




JZ 


ADJFEM 




IF THE SAME, ADJUST TO CHECK FOR FIFO EMPTY 






0085 


PC 




254 




MOV 


A, R4 




FIFO INPUT ADDRESS TO ACCUMULATOR 








0086 


07 




255 




DEC 


A 




DECREMENT FIFO INPUT ADDRESS IN 


ACCUMULATOR 






0087 


DD 




256 




XRL 


A, R5 




COMPARE INPUT TO OUTPUT FIFO ADDRESSES 








0088 


C691 




257 




JZ 


STATMT 




IF SAME, WRITE STATUS REGISTER FOR FIFO EMPTY 






008A 


049C 




258 




JMP 


CH0BF2 




CHECK OBF 










008C 


232F 




259 


ADJFEM 


MOV 


A. #FIFOTA 




FIFO TOP ADDRESS TO ACCUMULATOR 










008E 


DD 




260 




XRL 


A, R5 




COMPARE TOP TO OUTPUT FIFO ADDRESS 








008F 


969C 




261 




JNZ 


CH0BF2 




IF NOT SAME THEN FIFO IS NOT EMPTY, CHECK OBF 






0091 


2300 




S62 


STATMT 


MOV 


A, #OOH 




CLEAR BIT FOR FIFO EMPTY 










0093 


90 




263 




MOV 


STS, A 




WRITE TO STATUS REGISTER 










0094 


9ADF 




264 


INTRLO 


ANL 


P2, #0DFH 




FIFO EMPTY, INTERRUPT PORT 2-5 LOW 








0096 


FA 




265 




MOV 


A. R2 




SCAN ROW SELECT TO ACCUMULATOR 










0097 


53DF 




266 




ANL 


A, #ODFH 




SAVE INTERRUPT, NO CHANGE TO SCAN VALUE 








0099 


AA 




267 




MOV 


R2. A 




SCAN ROW SELECT REGISTER 










009A 


041D 




268 




JMP 


ADJREG 




ADJUST REGISTERS 










009C 


861D 




269 


CH0BF2 


JOBF 


ADJREG 




IF 0BF«1 THEN ADJUST REGISTERS 










009E 


046F 




270 
271 
272 




JMP 


ADJFOT 




ADJUST FIFO OUT ADDRESS TO LOAD 


DBBOUT 
















END 
















USER SYMBOLS 
























ADJFEM 


008C 


ADJFIN 005F 


ADJFOT 


006F ADJREG 


OOID 


CHCNTR 007D CHFFEM 0080 


CHFFUL 


0069 


CHOBFl 


006D 


CH0BF2 


009C 


DELAY2 0030 


ENCODE 


0045 FIFOBA 


0008 


FIFOTA 002F FILLMX OOOD 


INITMX 


0000 


INTRHl 


0059 


INTRLO 


0094 


LOADDB 0079 


LOADFF 


0052 OBFINT 


0018 


RRLOOK 003A RSETRG 0026 


RSFFIN 


0067 


RSFFOT 


0077 


SCANMX 


002C 


SCANTM OOOF 


BTATMT 


0091 STATNE 


0056 












ASSEMBLY COMPLETE. 


NO 


ERRORS 
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PROGRAMMABLE KEYBOARD INTERFACE 



Simultaneous Keyboard and Display 
Operations 



N-Key Rollover with Programmable 
Error Mode on Multiple New Closures 



interface Signals for Contact and 
Capacitive Coupled Keyboards 



Sixteen or Eight Character Seven- 
Segment Display Interface 



128-Key Scanning Logic 



Right or Left Entry Display RAM 



10.7msec Matrix Scan Time for 128 Keys 
and 6MHz Clock 



Depress/Release Mode Programmable 



Eight Character Keyboard FIFO 



interrupt Output on Key Entry 



This application is a general purpose programmable 
keyboard and display interface device designed for 
use with 8-bit microprocessors like the MCS-80 and 
MCS-85. The keyboard portion can provide a 
scanned interface to 128-key contact or capacitive- 
coupled keyboards. The keys are fully debounced 
with N-key rollover and programmable error genera- 
tion on multiple new key closures. Keyboard entries 
are stored in an 8-character FIFO with overrun sta- 



tus indication when more than 8 characters are en- 
tered. Key entries set an interrupt request output to 
the master CPU. 

The display portion of the UPI-41A provides a 
scanned display interface for LED, incandescent 
and other popular display technologies. Both nu- 
meric displays and simple indicators may be used. 
The UPI-41A has a 16X4 display RAM which can be 



RL 


c 


1 ^ 


^ 40 


3 


vcc 


X1 


E 


2 


39 


3 


CLR 


X2 


C 


3 


38 


3 


B3 


RESET 


c 


4 


37 


3 


B2 


NC 


c 


5 


36 


3 


Bl 


CS 


c 


6 


35 


3 


Bo 


GND 


c 


7 


34 


3 


KCL 


RD 


c 


8 


33 


3 


Me 


AO 


c 


9 


32 


3 


Ms 


WR 
SYNC 




^° 8041A ^' 
11 8741A 30 


3 
3 


M4 
M3 


Do 


c 


12 


29 


3 


M2 


D1 


c 


13 


28 


3 


M1 


D2 


c 


14 


27 


3 


Mo 


D3 


c 


15 


26 


3 


vdd 


D4 


E 


16 


25 


3 


NC 


D5 


c: 


17 


24 


3 


ERROR 


D6 


c 


18 


23 


3 


IRQ 


D7 


c 


19 


22 


3 


HYS 


GND 


c 


20 


21 


3 


BP 



SO: 



DATA 

BUS 

BUFFER 

REGISTER 



7T 



O 



INTERRUPT 
REQUEST 



WR - 
CS - 
Ac- 



Z1±L 



I/O 

CONTROL 

LOGIC 



JT 



o 



o 



C::> 



8-LEVEL 
KEY FIFO 



n 



it: 



SCAN 
OUTPUTS 



SCAN 
COUNTER 



TIMING 
IN 



ri 



Me 

ICO; 

Mo 



KEY 

DETECT 

& 

DEBOUNCE 

LOGIC 



TIMING 
IN 



TONE & ERROR 
LOGIC 



. SYNC 
(400 KHz) 



' TONE ENABLE 

► ERROR OUTPUT 

CLEAR INPUT 



CO 



16-DIGIT 
DISPLAY 
BUFFER 



CO 



TO 

DISPLAY 

DIGITS 



+5 • 
PWR - 
GND ■ 



INTERNAL 
BUS 



Figure 1. Pin Configuration 



Figure 2. Block Diagram 
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loaded or interrogated by the CPU. Both right entry 
calculator and left entry typewriter display formats 
are possible. Both read and write of the display 
RAM can be done with auto increment of the display 
RAM address. 

ORDERING INFORMATION: 

This part may be ordered as an 8041A with ROM 
code number 8278. The source code is available 
through Insite. 

Throughout this application of the UPI-41A, it will 
be referred to by its ROM code number, 8278. The 
8278 is packaged in a 40-pin DIP. The following is a 
brief functional description of each pin. 



PRINCIPLES OF OPERATION 

The following is a description of the major elements 
of the Programmable Keyboard/Display interface 
device. Refer to the block diagram in Figure 1. 

I/O Control and Data Buffers 

The I/O control section uses the CS, Aq, RD, and 
WR lines to control data flow to and from the var- 
ious internal registers and buffers (see Table2). All 
data flow to and from the 8278 is enabled by CS. The 
8-bits of information being transferred by the CPU 
is identified by Aq. A logic one means information is 
command or status. A log ic zero means the informa- 
tion is data. RD and WR determine the direction of 
data flow through the Data Bus Buffer (DBB). The 



Table 1. Pin Description 



Signal 


Pin. No. 


Type 


Name and Function 


D0-D7 


12-19 


I/O 


Data Bus: Three-state, bi-directional data bus lines used to transfer data and com- 
mands between the CPU and the 8278. 


WR 


10 


I 


Write: Write strobe which enables the master CPU to write data and commands be- 
tween the CPU and the 8278. 


RD 


8 


I 


Read: Read strobe which enables the master CPU to read data and status from the 
8278 internal registers. 


CS 


6 


I 


Chip Select: Chip select input used to enable reading and writing to the 8278. 


Ao 


9 


I 


Control/Data: Address input used by the CPU to indicate control or data. 


RESET 


4 


I 


Reset: A low signal on this pin resets the 8278. 


Xl,X2 


2,3 


I 


Freq. Reference Inputs: Inputs for crystal, L-C or external timing signal to deter- 
mine internal oscillator frequency. 


IRQ 


23 





Interrupt Request: Interrupt Request Output to the master CPU. In the keyboard 
mode the IRQ line goes low with each FIFO read and returns high if there is still infor- 
mation in the FIFO or an ERROR has occurred. 


M0-M6 


27-33 





Matrix Scan Lines: Matrix scan outputs. These outputs control a decoder which 
scans the key matrix columns and the 16 display digits. Also, the Matrix scan outputs 
are used to multiplex the return lines from the key matrix. 


RL 


1 


I 


Keyboard Return Line: Input from the multiplexer which indicates whether the key 
currently being scanned is closed. 


HYS 


22 





Hysteresis: Hysteresis output to the analog detector. (Capacitive keyboard configu- 
ration). A "0" means the key currently being scanned has already been recorded. 


KCL 


34 





Key Clock: Key Clock output to the analog detector (capacitive keyboard configura- 
tion) used to reset the detector before scanning a key. 


SYNC 


11 





Output Clock: High frequency (400 kHz) output signal used in the key scan to detect 
a closed key (capacitive keyboard configuration). 


B0-B3 


36-38 





Display Outputs: These four lines contain binary coded decimal display information 
synchronized to the keyboard column scan. The outputs are for multiplexed digital 
displays. 


ERROR 


24 





Error Signal: This line is high whenever two new key closures are detected during a 
single scan or when too many characters are entered into the keyboard FIFO. It is reset 
by a system RESET pulse or by a "1" input on the CLR pin or by the CLEAR ERROR 
command. 


CLR 


39 


I 


Clear Error: Input used to clear an ERROR condition in the 8278. 


BP 


21 





Tone Enable: Tone enable output. This line is high for 10ms following a valid key 
closure; it is set high and remains high during an ERROR condition. 


vcc» vdd 


40,26 


I 


Power: 4-5 volt power input: +5V ±10%. 


GND 


20,7 


I 


Ground: Signal ground. 
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DBB register is a bi-directional 8-bit buffer register 
which connects the internal 8278 bus buffer register 
to the external bus. When the chip is not selected 
(CS = 1) the DBB is in the hig h impeda nce state. 
The DBB acts as an input when (RD, WR, CS) = (1, 
0, 0) and an output when (RD, WR, CS) = (0, 1, 0). 

Table 2. I/O Control and Data Buffers 



CS 


AO 


WR 


RD 


Condition 








1 





Read DBB Data 





1 


1 





Read STATUS 











1 


Write Data to DBB 





1 





1 


Write Command to DBB 


1 


X 


X 


X 


Disable 8278 Bus, 
High Impedance 



Scan Counter 

The scan counter provides the timing to scan the 
keyboard and display. The four MSB's (M3-M6) 
scan the display digits and provide column scan to 
the keyboard via a 4 to 16 decoder. The three LSB's 
(M0-M2) are used to multiplex the row return lines 
into the 8278. 



Keyboard Debounce and Control 

The 8278 system configuration is shown in Figure 3. 
The rows of the matrix are scanned and the outputs 



are multiplexed by the 8278. When a key closure is 
detected, the debounce logic waits about 12 msec to 
check if the key remains closed. If it does, the ad- 
dress of the key in the matrix is transferred into a 
FIFO buffer. 



FIFO and FIFO Status 

The 8278 contains an 8X8 FIFO character buffer. 
Each new entry is written into a successive FIFO lo- 
cation and each is then read out in the order of entry. 
A FIFO status register keeps track of the number of 
characters in the FIFO and whether it is full or emp- 
ty. Too many reads or key entries will b e rec ognized 
as an error. The status can be read by a RD with CS 
low and Aq high. The status logic also provides a 
IRQ signal to the master processor whenever the 
FIFO is not empty. 



Display Address Registers and Display RAM 

The Display Address registers hold the address of 
the word currently being written or read by the CPU 
and the two 4-bit nibbles being displayed. The 
read/write addresses are programmed by CPU com- 
mand. They also can be set to auto increment after 
each read or write. The display RAM can be directly 
read by the CPU after the correct mode and address 
is set. Data entry to the display can be set to either 
left or right entry. 



TO 

8080. 8085 OR 8048 

MASTER 

PROCESSOR 



C 



^ 



-*► TO TONE GENERATOR 



ANALOG 
DETECTOR 



ERROR 
CLR 



KCL 
M2 



IRQ Ms 

8041A/ 

8741 A 
D0-D7 



WR 
RD 
Ao 

CS 

RESET 
83- • 



SYNC 
Me 




4 TO 16 
DECODE 



8 OR 16 DIGIT DISPLAY 



c 



ANALOG 
MULTIPLEXER 



CAPACITIVE 

KEYBOARD 

MATRIX 



16 DIGIT SCAN 



Figure 3. System Configuration for Capacitive-Coupied Keyboard 
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8080, 8085 OR 8048 

MASTER 

PROCESSOR 



c 



t> 



-► TO TONE GENERATOR 



CLR .^ 

IRQ Mo 

8041A/ 
8741 A 
D0-D7 



WR 
RD 
Ao 

CS 

RESET 



B3. 



DIGITAL 
MULTIPLEXER 



4 TO 16 
DECODE 



4 TO 16 
DECODE 



K 



16 DIGIT SCAN 



CONTACT 

KEYBOARD 

MATRIX 



8 OR 16 DIGIT DISPLAY 



Figure 4. System Configuration for Contact Keyboard 



COMMANDS 

The 8278 operating mode is programmed by the 
master CPU using the Aq, WR and D0-D7 inputs as 
shown below: 



Ao, CS INVALID 



X 



v^ 



D0-D7 



X 



y~EX 



Where the mode set bits are defined as follows: 
K — the keyboard mode select bit 

— normal key entry mode 

1 — special function mode: Entry on key closure 
and on key release 
D — the display entry mode select bit 

— left display entry 

1 — right display entry 
I — the interrupt request (IRQ) output enable bit. 

— enable IRQ output 

1 — disable IRQ output 
E — the error mode select bit 

— error on multiple key depression 

1 — no error on multiple key depression 
N — the number of display digits select 

— 16 display digits 

1 — 8 display digits 



The master CPU presents the proper command on 
the DQ-D7 data lines with Aq =1 and then sends a 
WR pulse. The com mand is latched by the 8278 on 
the rising edge of the WR and is decoded internally 
to set the proper operating mode. See the 
8041A/8741A data sheet for timing details. 

Command Summary 

KEYBOARD /DISPLAY MODE SET 

CODE 



NOTE: 

The default mode following a RESET input is all bits zero: 












N 


E 


1 


D 


K 





























READ FIF 


'0 COMMAND 


CODE 





1 




















READ on 


3PLAY COMMAND 


CODE 





1 


1 


Al 


A3 


As 


A1 


Ao 
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Where AI indicates Auto Increment and A3-A0 is 
the address of the next display character to be read 
out. 

AI = 1 AUTO increment 

AI = no AUTO increment 

WRITE DISPLAY COMMAND 

CODE 



1 








AI 


A3 


A2 


A1 


AO 



Where AI indicates Auto Increment and A3-A0 is 
the address of the next display character to be 
written. 



STATUS DESCRIPTION 

The S3 -So status bits indicate the number of entries 
(0 to 8) in the 8-level FIFO. A FIFO overrun will lock 
status at 1111. The overrun condition will prevent 
further key entries until cleared. 

A multiple key closure error will set the KE flag and 
prevent further key entries until cleared. 

The IBF and OBF flags signify the status of the 8278 
data buffer registers used to transfer information 
(data, status or commands) to and from the master 
CPU. 



CLEAR/BLANK COMMAND 

CODE 



1 





1 


UD 


BD 


CD 


OF 


GE 



Where the command bits are defined as follows: 

CE = Clear ERROR 

CF = Clear FIFO 

CD = Clear Display to all High 

BD = Blank Display to all High 

UD = Unblank Display 
The display is cleared and blanked following a 
Reset. 

Status Read 

The status register in the 8278 can be read by the 
master CPU using the Aq, RD, and D0-D7 inputs as 
shown below: 



X 



JZ 



\ r 



I 



The 8278 places 8-bits of status information on the 
D0-D7 lines following (Aq, CS, RD) = 1, 0, inputs 
from the master. 



The IBF flag is set when the master CPU writes 
Data or Commands to the 8278. The IBF flag is 
cleared by the 8278 during its response to the Data 
or Command. 

The OBF flag is set when the 8278 has output data 
ready for the master CPU. This flag is cleared by a 
master CPU Data READ. 

The Busy flag in the status register is used as a 
LOCKOUT signal to the master processor during re- 
sponse to any command or data write from the 
master. 

The master must test the Busy flag before each read 
(during a sequence) to be sure that the 8278 is ready 
with valid DATA. 

The ERROR and TONE outputs from the 8278 are 
set high for either type of error. Both types of error 
are cleared by the CLR input, by the CLEAR ER- 
ROR command, or by a reset. The FIFO and Display 
buffers are cleared independently of the Errors. 

FIFO status is used to indicate the number of char- 
acters in the FIFO and to indiate whether an error 
has occurred. Overrun occurs when the entry of an- 
other character into a full FIFO is attempted. Un- 
derrun occurs when the CPU tries to read an empty 
FIFO. The character read will be the last one en- 
tered. FIFO status will remain at 0000 and the error 
condition will not be set. 



Status Format 



S3 


82 


Si 


So 


B 


KE 


IBF 


OBF 



D7 De D5 D4 D3 D2 Di Do 

Where the status bits are defined as follows: 
IBF = Input Buffer Full Flag 
OBF = Output Buffer Full Flag 
KE = Keyboard Error Flag (multiple depression) 
B = BUSY Flag 
S3-S0 = FIFO Status 



Data Read 

The master CPU can read DATA from the 8278 
FIFO or Display buffers by using the Aq, RD, and 
D0-D7 inputs. 

The master sends a RD pulse with Aq = and CS = 
and the 8278 responds by outputting data on lines 
D0-D7. The data is strobed by the trailing edge of 
RD. 
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DATA READ SEQUENCE 

Before reading data, the master CPU must send a 
command to select FIFO or Display data. Following 
the command, the master must read STATUS and 
test the BUSY flag and the OBF flag to verify that 
the 8278 has responded to the previous command. A 
typical DATA READ sequence is as follows: 



_r 



t I 



READ DISPLAY FIRST 

OR FIFO COMMAND DATA BYTE 

FROM MASTER READY 



MASTER 
READS DATA 



8278 
PROCESSING 
NEXT BYTE 



After the first read following a Read Display or Read 
FIFO command, successive reads may occur as soon 
as OBF rises. 



Data Write 

The master CPU can write DATA to the 8278 Dis- 
play buffers by using the Aq, WR and D0-D7 inputs 
as follows: 



1 



=r~L 



1 t t 1 



WRITE DISPLAY 


8278 


MASTER 


8278 




8278 


COMMAND 


READY 


DATA WRITE 


READY 




READY 




FOR 


FIRST BYTE 








COMMAND 




MASTER WRITES 






OR DATA 




NEXT BYTE 





INTERFACE CONSIDERATIONS 

Scanned Keyboard Mode 

With N-key rollover each key depression is treated 
independently from all others. When a key is de- 
pressed the debounce logic waits for a full scan of 
128 keys and then checks to see if the key is still 
down. If it is, the key is entered into the FIFO. 

If two key closures occur during the same scan the 
ERROR output is set, the KE flag is set in the Status 
word, the TONE output is activated and IRQ is set, 
and no further inputs are accepted. This condition is 
cleared by a high signal on the CLEAR input or by a 
system RESET input or by the CLEAR ERROR 
command. 

In the special function mode both the key closure 
and the key release cause an entry to the FIFO. The 
release is entered with the MSB=1. 



Ao, CS INVALID 



K 



X 



Any key entry triggers the TONE output for 10ms. 



\ f 



The master CPU presents the Dat a on the D0-D7 
lines with Ao=0 and then sends a WR pulse. The 
data is latched by the 8278 on the rising edge of WR. 

DATA WRITE SEQUENCE 

Before writing data to the 8278, the master CPU 
must first send a command to select the desired dis- 
play entry mode and to specify the address of the 
next data byte. Following the commands, the master 
must read STATUS and test the BUSY flag (B) and 
IBF flag to verify that the 8278 has responded. A 
typical sequence is shown below. 



The HYS and KCL outputs enable the analog multi- 
plexer and detector to be synchronized for interface 
to capacitive coupled keyboards. 

Data Format 

In the scanned keyboard mode, the code entered 
into the FIFO corresponds to the position or address 
of the switch in the keyboard. The MSB is relevant 
only for special function keys in which code "0" sig- 
nifies closure and "1" signifies release. The next four 
bits are the column count which indicates which col- 
umn the key was found in. The last three bits are 
from the row counter. 



7 


6 


5 


4 


3 


2 


1 





SF 


Me 


M5 


M4 


M3 


M2 


M^ 


Mo 



1 FOR SPECIAL FUNCTION 
-MODE AND KEY RELEASED 
FOR KEY DEPRESSED 



Display 

Display data is entered into a 16X4 display register 
and may be entered from the left, from the right or 
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Figure 5. Keyboard Timing 
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Figure 6. Key Entry and Error Timing 
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Figure 7. Display Timing 
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into specific locations in the display register. A new 
data character is put out on B0-B3 each time the 
M6-M3 lines change (i.e., once every 0.75ms with a 6 
MHz crystal). Data is blanked during the time the 
column select lines change by raising the display 
outputs. Output data is positive true. 

LEFT ENTRY 

The left entry mode is the simplest display format in 
that each display position in the display corresponds 
to a byte (or nibble) in the Display RAM. ADDRESS 
in the RAM is the left-most display character and 
ADDRESS 15 is the right-most display character. 
Entering characters from position zero causes the 
display to fill from the left. The 17th character is en- 
tered back in the left-most position and filling again 
proceeds from there. 

RIGHT ENTRY 

Right entry is the method used by most electronic 
calculators. The first entry is placed in the right- 
most display character. The next entry is also placed 
in the right-most character after the display is 
shifted left one character. The left-most character is 
shifted off the end and is lost. 

DISPLAY 
12 14 15 RAM 

ADDRESS 



17TH ENTRY 













1 


2 


3 15 





1 










1 


2 


3 


4 


1 


2 








1 


2 


3 





1 13 


14 


15 


1 


2 




14 


15 


16 


1 


2 14 


15 





2 


3 




15 


16 


17 


2 


3 15 





1 


3 


4 




16 


17 


18 



AUTO INCREMENT 

In the Left Entry mode, Auto Incrementing causes 
the address where the CPU will next write to be in- 
cremented by one and the character appears in the 
next location. With non-Auto Incrementing the en- 
try is both to the same RAM address and display po- 
sition. Entry to an arbitrary address in the Left 
Entry — Auto Increment mode has no undesirable 
side effects and the result is predictable: 



1ST ENTRY 
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1 
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2 
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7 
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2 















DISPLAY 

RAM 

ADDRESS 



ENTER NEXT AT LOCATION 5 AUTO INCREMENT 

12 3 4 5 6 7 



1 2 3 

12 3 4 5 6 7 

1 I 2 I I I I 3 I 4 



In the Right Entry mode. Auto Incrementing and 
non-Incrementing have the same effect as in the Left 
Entry except that the address sequence is inter- 
rupted. 

DISPLAY 
12 3 4 5 6 7 RAM 

ADDRESS 



COMMAND 
10010101 



2 3 4 5 6 7 1 

1 2 

2 3 4 5 6 7 1 

I I I I I 1 I 2 



Note that now the display position and register ad- 
dress do not correspond. Consequently, entering a 
character to an arbitrary position in the Auto Incre- 
ment mode may have unexpected results. Entry 
starting at Display RAM ADDRESS with sequen- 
tial entry is recommended. A Clear Display com- 
mand should be given before display data is entered 
if the number of data characters is not equal to 16 (or 
8) in this mode. 



ENTER NEXT AT LOCATION 5 AUTO INCREMENT 



3 4 5 6 7 12 

3 1 2 

4 5 6 7 12 3 

3 4 12 
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Starting at an arbitrary location operates as shown 
below. 



COMMAND 
10010101 



DISPLAY 
12 3 4 5 6 7 RAM 

ADDRESS 



ENTER NEXT AT LOCATION 5 AUTO INCREMENT 

12 3 4 5 6 7 



1ST ENTRY 










1 










2 3 4 5 6 7 1 


2ND ENTRY 








1 


2 












8TH ENTRY 


4 


5 


6 


7 


8 


1 


2 


3 






9TH ENTRY 


5 


6 


7 


8 


9 


2 


3 


4 



Entry appears to be from the initial entry point. 



6-66 




^CMAPfER*!^ 
DATASHEET^ 




^■:V"^' 




■■■■;-. 




.-.#■.. 




■'-!': 




■-:t' 


■^■-%y' ■ :-;:i; 








..■:.•„ 












-^1 






























:'- 




i. 




















\ 




11 








■—■—»•■ 


r —— T w 


i- 


, i ..^■■i 




) 


[ 

1 

.? 

I 

1 


^ f 


w 
r 

J 


A 

w 




I ': 


I 
J- 


^^^^^^^m 



Intel 



8041 A/8641 A/8741 A 

UNIVERSAL PERIPHERAL INTERFACE 

8-BIT MICROCOMPUTER 



8-Bit CPU plus ROM, RAM, I/O, Timer 
and Clock in a Single Package 

One 8-Bit Status and Two Data Regis- 
ters for Asynchronous Slave-to-Master 
Interface 

DMA, Interrupt, or Polled Operation 
Supported 

1024 X 8 ROM/EPROM, 64 x 8 RAM, 
8-Bit Timer/Counter, 18 Programmable 
I/O Pins 



Fully Compatible with MCS-48"', 
MCS-80'", MCS-85'^ and MCS-86'^ 
Microprocessor Families 

Interchangeable ROM and EPROM 

Versions 

3.6 MHz 8741 A-8 Available 

Expandable I/O 

RAM Power-Down Capability 

Over 90 Instructions: 70% Single Byte 

Single 5V Supply 



The Intel® 8041 A/8741 A is a general purpose, programmable Interface device designed for use with a variety of 8-blt 
microprocessor systems. It contains a low cost microcomputer with program memory, data memory, 8-bit CPU, I/O 
ports, timer/counter, and clock in a single 40-pin package. Interface registers are included to enable the DPI device to 
function as a peripheral controller in MCS-48'^'^, MCS-80™, MCS-85™, MCS-86™ and other 8-bit systems. 

The UPI-41 A"""^ has 1 K words of program memory and 64 words of data memory on-chip. To allow full user flexibility the 
program memory Is available as ROM in the 8041 A version or as UV-erasable EPROM in the 8741 A version. The 8741 A 
and the 8041 A are fully pin compatible for easy transition from prototype to production level designs. The 8641 A is a 
one-time programmable (at the factory) 8741 A which can be ordered as the first 25 pieces of a new 8041 A order. The 
substitution of 8641A's for 8041 A's allows for very fast turnaround for initial code verification and evaluation results. 

The device has two 8-bit, TTL compatible I/O ports and two test inputs. Individual port lines can function as either in- 
puts or outputs under software control. I/O can be expanded with the 8243 device which is directly compatible and has 
16 I/O lines. An 8-bit programmable timer/counter is included in the DPI device for generating timing sequences or 
counting external inputs. Additional UPI features include: single 5V supply, low power standby mode (in the 8041A), 
single-step mode for debug (in the 8741A), and dual working register banks. 

Because it's a complete microcomputer, the UPI provides more flexibility for the designer than conventional LSI inter- 
face devices. It is designed to be an efficient controller as well as an arithmetic processor. Applications include key- 
board scanning, printer control, display multiplexing and similar functions which involve interfacing peripheral 
devices to microprocessor systems. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



TEST C 1 

XTAL1 C 2 

XTAL2 C 3 

RESETC 4 

SSC 5 

CSC 6 

EAC 7 

RDC 8 

AoC 9 

WBC 10 

SYNCC 11 

DoC 12 

DlC 13 

D2C 14 

03 C 15 

D4C 16 

DsC 17 

Dec 18 

D7C 19 
VSSC 20 



8041 A/ 
8741 A 30 



DVCC 

Dtesti 
;;3P27/CSCK 

Z] P28'DRQ 

■J P24'OBF 

I|P17 

I1P16 

DP15 

DP14 

I1P13 

DP12 

DPlI 

UPlO 

HVDD 

Uprog 

I1P23 
IIP22 
IIP21 
IIP20 



MASTER 
SYSTEM 
INTERFACE 



STATUS ^ 
REGISTER XT" 

— TV 



~^-<M^ 



-nJ instruction I/i — \ 

V^1^0ECODER_|\r— i/ 



ACCUMULATOR 



IC: 



^ 



CRYSTAL fxTALI 
LC, OR 
CLOCK 



I XTAL2 ► 



* PROM PROGRAM SUPPLY 

* + 5 SUPPLY 
-.> GROUND 



C:^ 



^ 




REG. BANK 
I MULTIPLEXER 



C=^Z 



64x8 
RANDOM 
ACCESS 



PROM/ROM 
PROGRAM 
MEMORY 



S PROGRAM 
I ^ COUNTER 



10GRAM I 



PORT 4-7 
EXPANDER 
INTERFACE 



^ \P: 

\ /P; 



CONDITIONAL 
BRANCH 
LOGIC 



EVENT COUNTER 



7-1 



8041 A/8641 A/8741 A 



UPI-41A™ FEATURES AND 
ENHANCEMENTS 



Two Data Bus Buffers, one for Input and one for out- 
put. This allows a much cleaner Master/Slave pro- 
tocol. 



INPUT 

DATA 

BUS 

BUFFER 

(8) 



INTERNAL 
DATA BUS 



OUTPUT 
DATA 
BUS 

BUFFER 
(8) 



N\a/^ 



If "EN FLAGS" has been executed, P25 becomes the 
IBF (Input Buffer Full) pin. A "1" written to P25 
enables the IBF pin (the pin outputs the Inverse of the 
IBF Status Bit). A "0" written to P25 disables the IBF 
pin (the pin remains low). This pin can be used to 
indicate that the UPI-41A is ready for data. 



«-OBF (INTERRUPT REQUEST) 



- IBF (INTERRUPT REQUEST) 




2. 8 Bits of Status 



DATA BUS BUFFER INTERRUPT CAPABILITY 



ST7 


ST6 


ST5 


ST4 


F1 


FO 


IBF 


DBF 



EN FLAGS Op Code: 0F5H 



D5 D4 



Dl Do 



ST4-ST7 are user definable status bits. These bits are 
defined by the "MOV STS, A" single byte, single 
cycle instruction. Bits 4-7 of the accumulator are 
moved to bits 4-7 of the status register. Bits 0-3 of 
the status register are not affected. 

MOV STS, A Op Code: 90H 



10 



3. RD and WR are edge triggered. IBF, OBF, Fi and INT 
change internally after the trailing edge of RD or WR. 



FLAGS AFFECTED 



\. 



1 



Do 



P26 and P27 are port pins or DMA handshake pins for 
use with a DMA controller. These pins default to port 
pins on Reset. 

If the "EN DMA" instruction has been executed, P26 
becomes the DRQ (DMA ReQuest) pin. A "1" written 
to P26 causes a DMA request (DRQ is activated). DRQ 
is deactivated by DACK • RD, DACK • WR, or execution 
of the "EN DMA" instruction. 

If "EN DMA" has been executed, P27 becomes the 
DACK (DMA ACKnowledge) pin. This pin acts as a 
chip select input for the Data Bus Buffer registers 
during DMA transfers. 



4. P24 and P25 are port pins or Buffer Flag pins which 
can be used to interrupt a master processor. These 
pins default to port pins on Reset. 

If the "EN FLAGS" instruction has been executed, 
P24 becomes the OBF (Output Buffer Full) pin. A "1" 
written to P24 enables the OBF pin (the pin outputs 
the OBF Status Bit). A "0" written to P24 disables the 
OBF pin (the pin remains low). This pin can be used 
to indicate that valid data is available from the UPI- 
41A (in Output Data Bus Buffer). 



8041 A/ 
8741 A 



DRQ P26 



DACK P27 



DMA HANDSHAKE CAPABILITY 



EN DMA Op Code: 0E5H 



110 10 
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PIN DESCRIPTION 



Signal Description 



UPI™ INSTRUCTION SET 



D0-D7 
(BUS) 

PlO"Pl7 
P20"P27 



WR 

RD 

CS 

Ao 

TEST 0, 
TEST1 



XTAL1, 
XTAL2 

SYNC 



EA 
PROG 



RESET 



SS 



Three-state, bidirectional DATA BUS BUFFER lines 
used to interface the UPI-41A to an 8-bit master 
system data bus. 

8-bit, PORT 1 quasl-bldlrectlonal I/O lines. 

8-bit, PORT 2 quasi-bidlrectlonal I/O lines. The lower 
4 bits {P20-P23) interface directly to the 8243 I/O ex- 
pander device and contain address and data infor- 
mation during PORT 4-7 access. The upper 4 bits 
(P24-P27) can be programmed to provide Interrupt 
Request and DMA Handshake capability. Software 
control can configure P24 as OBF (Output Buffer 
Full), P25 as IBF (Input Buffer Full ), P26 a s DRQ 



and P27 as DACK (DMA 



(DMA Request), 
ACKnowledge). 

I/O write input which enables the master CPU to 
write data and command words to the UPI-41A IN- 
PUT DATA BUS BUFFER. 

I/O read input which enables the master CPU to 
read data and status words from the OUTPUT DATA 
BUS BUFFER or status register. 

Chip select input used to select one UPI-41A out of 
several connected to a common data bus. 

Address input used by the master processor to in- 
dicate whether byte transfer is data or command. 

Input pins which can be directly tested using condi- 
tional branch instructions. 

Ti also functions as the event timer input (under 
software control). Tq is used during PROM program- 
ming and verification in the 8741A. 

Inputs for a crystal, LC or an external timing signal 
to determine the internal oscillator frequency. 

Output signal which occurs once per UPI-41A in- 
struction cycle. SYNC can be used as a strobe for 
external circuitry; it is also used to synchronize 
single step operation. 

External access input which allows emulation, 
testing and PROM/ROM verification. 

Multifunction pin used as the program pulse input 
during PROM programming. 

During I/O expander access the PROG pin acts as 
an address/data strobe to the 8243. 

Input used to reset status flip-flops and to set the 
program counter to zero. 



RESET is also used during PROM programming and 
verification. 

Single step input used in the 8741A in conjunction 
with the SYNC output to step the program through 
each instruction. 

+ 5V main power supply pin. 

-h5V during normal operation. -i-25V during pro- 
gramming operation. Low power standby pin in 
ROM version. 

Circuit ground potential. 



Mn#monlc 


Description Bytts CyciM 


ACCUMULATOR 




ADD A.Rr 


Add register to A 1 




ADD A,(®Rr 


Add data memory to A 1 




ADD A,#data 


Add immediate to A 2 




ADDC A.Rr 


Add register to A with carry 1 




ADDC A,@Rr 


Add data memory to A with carry 1 




ADDC A,#data 


Add immed. to A with carry 2 




ANL A,Rr 


AND register to A 1 




ANL A,(®Rr 


AND data memory to A 1 




ANL A.#clata 


AND immediate to A 2 




ORL A.Rr 


OR register to A 1 




ORL A.(a)Rr 


OR data memory to A 1 




ORL A.#data 


OR immediate to A 2 




XRL A.Rr 


Exclusive OR register to A 1 




XRL A.@Rr 


Exclusive OR data memory to A 1 




XRL A,#data 


Exclusive OR immediate to A 2 




INC A 


Increment A 1 




DEC A 


Decrement A 1 




CLRA 


Clear A 1 




CPLA 


Complement A 1 




DA A 


Decimal Adjust A 1 




SWAP A 


Swap nibbles of A 1 




RL A 


Rotate A left 1 




RLCA 


Rotate A left through carry 1 




RRA 


Rotate A right 1 




RRCA 


Rotate A right through carry 1 




INPUT/OUTPUT 




IN A.Pp 


Input port to A 1 


2 


OUTL Pp,A 


Output A to port 1 


2 


ANL Pp,#data 


AND immediate to port 2 


2 


ORL Pp.#data 


OR immediate to port 2 


2 


IN A.DBB 


Input DBB to A. clear IBF 1 


1 


OUT DBB.A 


Output A to DBB, set OBF 1 


1 


MOV STS.A 


A4-A7 to Bits 4-7 of Status 1 


1 


MOVD A.Pp 


Input Expander port to A 1 


2 


MOVD Pp.A 


Output A to Expander port 1 


2 


ANLD Pp.A 


AND A to Expander port 1 


2 


ORLD Pp.A 


OR A to Expander port 1 


2 


DATA MOVES 






MOV A.Rr 


Move register to A 1 




MOV A,(aRr 


Move data memory to A 1 




MOV A.#data 


Move immediate to A 2 




MOV Rr.A 


Move A to register 1 




MOV (®Rr.A 


Move A to data memory 1 




MOV Rr.#data 


Move immediate to register 2 




MOV @Rr,#data Move immediate to data memory 2 




MOV A.PSW 


Move PSW to A 1 




MOV PSW.A 


Move A to PSW 1 




XCH A.Rr 


Exchange A and register 1 




XCH A.@Rr 


Exchange A and data memory 1 




XCHD A.@Rr 


Exchange digit of A and register 1 




MOVP A,@A 


Move to A from current page 1 


2 


M0VP3. A,@A 


Move to A from page 3 1 


2 


TIMER/COUNTER 




MOV A,T 


Read Timer/Counter 1 




MOV T.A 


Load Timer/Counter 1 




STRTT 


Start Timer 1 




STRT CNT 


Start Counter 1 




STOP TCNT 


Stop Timer/Counter 1 




EN TCNTI 


Enable Timer/Counter Interrupt 1 




DIS TCNTI 


Disable Timer/Counter Interrupt 1 
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Mnemonic 


Description 


Bytes 


Cycles 


IMnemonic 


Description 


Bytes 


Cycles 


CONTROL 








CPLFO 


Complement Flag 


1 


1 


EN DMA 


Enable DMA Handshake Lines 


1 


1 


CLRF1 


Clear F1 Flag 


1 


1 


ENI 


Enable IBF Interrupt 


1 


1 


CPLF1 


Complement F1 Flag 


1 


1 


DISI 


Disable IBF Interrupt 


1 


1 










EN FLAGS 


Enable Master Interrupts 


1 


1 










SEL RBO 


Select register bank 


1 


1 


BRANCH 








SEL RBI 
NOP 


Select register bank 1 
No Operation 


1 
1 


1 

1 


JMPaddr 
JMPP @A 


Jump unconditional 
Jump indirect 


2 

1 


2 
2 


REGISTERS 








DJNZ Rr, addr 


Decrement register and jump 


2 


2 










JC addr 


Jump on Carry = 1 


2 


2 


INCRr 


Increment register 


1 


1 


JNC addr 


Jump on Carry = 


2 


2 


INC @Rr 


Increment data memory 


1 


1 


JZ addr 


Jump on A Zero 


2 


2 


DEC Rr 


Decrement register 


1 


1 


JNZaddr 


Jump on A not Zero 


2 


2 










JTO addr 


Jump on TO = 1 


2 


2 


SUBROUTINE 








JNTO addr 


Jump on T0 = 


2 


2 


CALL addr 


Jump to subroutine 


2 


2 


JT1 addr 


Jump on T1 = 1 


2 


2 


RET 


Return 


1 


2 


JNT1 addr 


Jump on T1 =0 


2 


2 


RETR 


Return and restore status 


1 


2 


JFO addr 


Jump on FO Flag = 1 


2 


2 










JF1 addr 


Jump on F1 Flag=1 


2 


2 


FLAGS 








JTF addr 


Jump on Timer Flag = 1 , Clear Flag 


2 


2 


CLRC 


Clear Carry 


1 


1 


JNIBFaddr 


Jump on IBF Flag = 


2 


2 


CPLC 


Complement Carry 


1 


1 


JOBF addr 


Jump on OBF Flag= 1 


2 


2 


CLRFO 


Clear Flag 


1 


1 


JBb addr 


Jump on Accumulator Bit 


2 


2 



APPLICATIONS 




TO 

PERIPHERAL 

DEVICES 



RD 

WR 
8 

PORT 
BUS 



8041 A/ 
8741 A 



(^ 
^ 



Dbb 



TO 

PERIPHERAL 

DEVICES 



Figure 1. 8085A-8041A Interface 



Figure 2. 8048-8041 A Interface 



8243 
EXPANDER 



iz 






KEYBOARD 
MATRIX 



PORT 2 PROG 



Dbb 



7> 



CONTROL BUS 







DOT MATRIX PRINTER 






FORM 










PRINT LF. HOLD 




SOLENOIDS 
















1 




f^ 










Z 




















o 


S: 
























o 


OC 

o 


o 
























MOTOR 




a. 


"■ 




SOLENOID 






DRIVERS 




z 


u. 

z 




DRIVERS 
















- 


A 


jii 


























7 OR 9 






PORT 2 


PORT 2 
8041 A/8741 A 


PORT 1/PORT 2 






Dbb 


CONTROL 







/\ 



CONTROL BUS 



JL 



Figure 3. 8041A-8243 Keyboad Scanner 



Figure 4. 8041 A Matrix Printer Interface 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias CCtoZO'C 

Storage Temperature - 65X to + 150X 

Voltage on Any Pin With Respect 

to Ground 0.5V to +7V 

Power Dissipation 1 .5 Watt 



*COMMENT: Stresses above those listed under "Absolute Maximum 
Ratings" may cause permanent damage to the device. This is a stress 
rating only and functional operation of the device at these or any other 
conditions above those indicated in the operational sections of this 
specification is not implied. Exposure to absolute maximum rating con- 
ditions for extended periods may affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 

Ta=0°C to70°C, Vss = OV, 8041A: Vcc = Vdd= +5V± 10%, 8741 A: Vcc = Vdd= +5V±5% 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


V,L 


Input Low Voltage (Except XTAL1, XTAL2, RESET) 


-0.5 


0.8 


V 




V|L1 


Input Low Voltage (XTAL1, XTAL2, RESET) 


-0.5 


0.6 


V 




V,H 


Input High Voltage (Except XTAL1 , XTAL2, RESET) 


2.2 


Vcc 






V|H1 


Input High Voltage (XTAL1, XTAL2, RESET) 


3.8 


Vcc 


V 




Vol 


Output Low Voltage (D0-D7) 




0.45 


V 


loL=2.0 mA 


Vqu 


Output Low Voltage (PioPi7» ^20^27. Sync) 




0.45 


V 


loL=1-6 mA 


V0L2 


Output Low Voltage (Prog) 




0.45 


V 


loL=10 mA 


Vqh 


Output High Voltage (D0-D7) 


2.4 




V 


loH=-400/.A 


Vqhi 


Output High Voltage (All Other Outputs) 


2.4 




V 


loH=-50/xA 


l|L 


Input Leakage Current (Tq, Ti, RD, WR, OS, Aq, EA) 




±10 


mA 


Vss ^ V|N < Vcc 


Iqz 


Output Leakage Current (Dq-D/, High Z State) 




±10 


;^A 


Vss + 0.45 < V|N< Vcc 


Ili 


Low Input Load Current (P10P17, P20P27) 




0.5 


mA 


V,L=0.8V 


Ilii 


Low Input Load Current (RESET, SS) 




0.2 


mA 


V|L=0.8V 


'dd 


Vdd Supply Current 




15 


mA 


Typical =5 mA 


'cc+'dd 


Total Supply Current 




125 


mA 


Typical = 60 mA 



AC. CHARACTERISTICS 



Ta = OX to 70 X, Vss = OV, 8041 A: Vcc = Vdd= +5V ± 10%, 8741 A: Vcc = 
DBB READ 


Vdd=+5V ±5% 




Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAR 


CS, AoSetupto RDl 







ns 




tRA 


CS, Ao Hold After RDt 







ns 




tRR 


RD Pulse Width 


250 




ns 




tAD 


CS, Aq to Data Out Delay 




225 


ns 


Cl=150pF 


tRD 


RDl to Data Out Delay 




225 


ns 


Cl=150pF 


tpF 


RDt to Data Float Delay 




100 


ns 




tcY 


Cycle Time (Except 8741A-8) 


2.5 


15 


(iS 


6.0MHZXTAL 


tcY 


Cycle Time (8741 A-8) 


4.17 1 


15 


fiS 


3.6MHZXTAL 


DBB WRITE 


Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Uw 


CS, AoSetupto WRl j 







ns 




^WA 


CS, Ao Hold After WRt 







ns 




tww 


WR Pulse Width 


250 




ns 




*DW 


Data Setup to WRt 


150 




ns 




*WD 


Data Hold After WRt 







ns 
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INPUT AND OUTPUT WAVEFORMS FOR A.C. TESTS 



2.4 " 
0.45 • 



n OBTEST POINTSr'^" 






Cl = 150pF 



WAVEFORMS 



1. READ OPERATION-DATA BUS BUFFER REGISTER. 



CSOR Ao 



zy: 



X 



/ 



< 



" DATA VALID *■ 



> 



\. 



(READ CONTROL) 



2. WRITE OPERATION-DATA BUS BUFFER REGISTER. 



C5 0R Ao 




K 



Y- DATA VALID ►Y 



(WRITE CONTROL) 



TYPICAL 8041/8741A CURRENT 

80 mA 



J L 



40° 60° 

TEMP (°C) 
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A.C. CHARACTERISTICS-PORT 2 

TA = 0°Cto70''C, 8041A: Vcc= +5V ±10%,8741A: Vcc= +5V ±5% 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tCP 


Port Control Setup Before Falling 
Edge of PROG 


110 




ns 




tpc 


Port Control Hold After Falling 
Edge of PROG 


100 




ns 




tpR 


PROG to Time P2 Input Must Be Valid 




810 


ns 




tPF 


Input Data Hold Time 





150 


ns 




top 


Output Data Setup Time 


250 




ns 




tPD 


Output Data Hold Time 


65 




ns 




tpp 


PROG Pulse Width 


1200 




ns 





PORT 2 TIMING 



EXPANDER 
PORT 



EXPANDER 
PORT 



OCZI 



DC 



PORT 20-3 DATA 



PORT 2o-3 DATA 



J V 



X 



PORT CONTROL 



X 



OUTPUT DATA 



;c 



V PCPTCONTRO. V tZ^TK 



I 



A.C. CHARACTERISTICS— DMA 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Ucc 


DACK to WR or RD 







ns 




tcAC 


RD or WR to DACK 







ns 




UCD 


DACK to Data Valid 




225 


ns 


Cl=150pF 


*CRQ 


RD or WR to DRQ Cleared 




200 


ns 





WAVEFORMS- DMA 

DACK V 



f 



\ / 



)C^^ 



\ 



"\ 



/ 



> f 

-^tcA 

3G^DC 



\ 
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CRYSTAL OSCILLATOR MODE 



DRIVING FROM EXTERNAL SOURCE 



< 15 pF 
(INCLUDES XTAL, 
SOCKET, STRAY) 



F 



-o 



15-25 pF =. 
(INCLUDES SOCKET, 
STRAY) 



CRYSTAL SERIES RESISTANCE SHOULD BE <75Q AT 6 MHz; <180Q AT 3.6 MHz. 



BOTH XTAL1 AND XTAL2 SHOULD BE DRIVEN. 
RESISTORS TO Vcc ARE NEEDED TO ENSURE Vih = 3.8V 
IF TTL CIRCUITRY IS USED. 



LC OSCILLATOR MODE 



45 mH 20 pF 5.2 MHz 

120 mH 20 pF 3.2 MHz 




C'= 



C + 3Cpp 



Cpp = 5-10 pF PINTO-PIN 
XTAL2 CAPACITANCE 



EACH C SHOULD BE APPROXIMATELY 20 pF, INCLUDING STRAY CAPACITANCE. 



PROGRAMMING, VERIFYING, AND 
ERASING THE 8741A EPROM 

Programming Verification 

In brief, the programming process consists of: activating 
the program mode, applying an address, latching the 
address, applying data, and applying a programming pulse. 
Each word is programmed completely before moving on to 
the next and is followed by a verification step. The follow- 
ing is a list of the pins used for programming and a descrip- 
tion of their functions: 



Pin 


Function 


XTAL1 


Clock Input (1 to6MHz) 


Reset 


Initialization and Address Latching 


TestO 


Selection of Program or Verify Mode 


EA 


Activation of Program/Verify Modes 


BUS 


Address and Data Input 




Data Output During Verify 


P20-1 


Address Input 


Vdd 


Programming Power Supply 


PROG 


Program Pulse Input 



WARNING: 

An attempt to program a missocketed 8741 A will result in severe 
damage to the part. An indication of a properly socketed part is the 
appearance of the SYNC clock output. The lack of this clock may 
be used to disable the programmer. 

The Program/Verify sequence is: 



2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 

10. 

11. 

12. 

13. 

14. 

15. 



Aq = OV, CS = 5V, EA = 5V, RESET = OV, TESTO = 5V, 
Vqq = 5V, clock applied or internal oscillator operating, 
BUS and PROG floating. 

Insert 8741 A in programming socket 

TEST = Ov (select program mode) 

EA = 23V (activate program mode) 

Address applied to BUS and P20-1 



RESET = 5v (latch address) 

Data applied to BUS 

Vqq = 25v (programming power) 

PROG = Ov followed by one 50ms pulse to 23V 

Vdd = 5v 

TEST = 5v (verify mode) 

Read and verify data on BUS 

TEST = Ov 



RESET = Ov and repeat from step 5 

Programmer should be at conditions of step 1 when 
8741 A is removed from socket. 
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8741 A Erasure Characteristics 

The erasure characteristics of the 8741 A are such that 
erasure begins to occur when exposed to light with 
wavelengths shorter than approximately 4000 Ang- 
stroms (A). It should be noted that sunlight and certain 
types of fluorescent lamps have wavelengths in the 
3000-4000A range. Data show that constant exposure to 
room level fluorescent lighting could erase the typical 
8741 A in approximately 3 years while it would take ap- 
proximately one week to cause erasure when exposed 
to direct sunlight. If the 8741 A is to be exposed to these 
types of lighting conditions for extended periods of 
time, opaque labels are available from Intel which 



should be placed over the 8741 A window to prevent 
unintentional erasure. 

The recommended erasure procedure for the 8741 A is 
exposure to shortwave ultraviolet light which has a 
wavelength of 2537 A. The integrated dose (i.e., UV inten- 
sity x exposure time) for erasure should be a minimum 
of 15 w-sec/cm^. The erasure time with this dosage is 
approximately 15 to 20 minutes using an ultraviolet 
lamp with a 12,000 f^W/cm^ power rating. The 8741 A 
should be placed within one inch of the lamp tubes dur- 
ing erasure. Some lamps have a filter on their tubes 
which should be removed before erasure. 



A.C. TIMING SPECIFICATION FOR PROGRAMMING 



25X ±5''C, Vcc = 5V ±5%, Vo 



25V ±1V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAW 


Address Setup Time to RESET t 


4tcy 








tWA 


Address Hold Time After RESET t 


4tcy 








tow 


Data in Setup Time to PROG t 


4tcy 








tWD 


Data in Hold Time After PROG i 


4tcy 








tPH 


RESET Hold Time to Verify 


4tcy 








tvDDW 


Vdd Setup Time to PROG ! 


4tcy 








tVDDH 


Vdd Hold Time After PROG i 











tPW 


Program Pulse Width 


50 


60 


mS 




tTW 


Test Setup Time for Program Mode 


4tcy 








tWT 


Test Hold Time After Program Mode 


4tcy 








too 


Test to Data Out Delay 




4tcy 






tww 


RESET Pulse Width to Latch Address 


4tcy 








tr. tf 


Vdd and PROG Rise and Fall Times 


0.5 


2.0 


MS 




tCY 


CPU Operation Cycle Time 


5.0 




MS 




tRE 


RESET Setup Time Before EA t. 


4tcy 









Note: If TEST is high, t^Q can be triggered by RESET t . 



D.C. SPECIFICATION FOR PROGRAMMING 

Ta = 25°C ± 5°C, Vcc = 5V ± 5%, Vdd = 25V ± 1 V 



Symbol 


Parameter 


IVIin. 


Max. 


Unit 


Test Conditions 


Vdoh 


Vdd Program Voltage High Level 


24.0 


26.0 


V 




Vddl 


Vdd Voltage Low Level 


4.75 


5.25 


V 




VPH 


PROG Program Voltage High Level 


21.5 


24.5 


V 




VPL 


PROG Voltage Low Level 




0.2 


V 




Veah 


EA Program or Verify Voltage High Level 


21.5 


24.5 


V 




Veal 


EA Voltage Low Level 




5.25 


V 




Idd 


Vdd High Voltage Supply Current 




30.0 


mA 




IPROG 


PROG High Voltage Supply Current 




16.0 


mA 




Iea 


EA High Voltage Supply Current 




1.0 


mA 
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WAVEFORMS FOR PROGRAMMING 



COMBINATION PROGRAM/VERIFY MODE (EPROM'S ONLY) 



DB0-DB7 




ADDRESS (8-9) VALID 



7 



\ 



-tVDDH 

I twT- 



\ _ / Y DATA \ _^ / NEXT ADDR V^ 

D/""" " ^ ^ VALID y ~ ■" ""VVAUD^A 



\_... 



y- 



■^ 



NEXT 
ADDRESS 



VERIFY MODE (ROM/EPROM) 



V 




/ V 




/ \ 


^- 


-<. 


ADDRESS W" DATA OUT \ 
(0-7) VALID A^ VALID /~ 


-< 


NEXT V NEXTDATaV 
ADDRESS A OUT VALID /" 




JL 


ADDRESS (8-9) VALID 


JC 


NEXT ADDRESS VAL^D 



DB0-DB7 



NOTES: 

1. PROG MUST FLOAT IF EA IS LOW (Le., :^23V), OR IF T0 = 5V FOR THE 8741 A. FOR THE 
8041A PROG MUST ALWAYS FLOAT. 

2. XTAL1 AND XTAL 2 DRIVEN BY 3.6 MHz CLOCK WILL GIVE 4.17 ,tsec tcv- THIS IS ACCEPT- 
ABLE FOR 8741A-8 PARTS AS WELL AS STANDARD PARTS. 

3. AO MUST BE HELD LOW (l.e., = OV) DURING PROGRAM/VERIFY MODES. 



The 8741A EPROM can be programmed by either of two 
Intel products: 

1. PROMPT-48 Microcomputer Design Aid, or 

2. Universal PROM Programmer (UPP series) peripheral 
of the Intellec® Development System with a UPP-848 
Personality Card. 
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8243 
MCS-48^- INPUT/OUTPUT EXPANDER 



Low Cost 

Simple Interface to MCS-48^'' Micro- 
computers 
Four 4-Bit I/O Ports 
AND and OR Directly to Ports 



24-Pin DIP 

Single 5V Supply 

High Output Drive 

Direct Extension of Resident 8048 I/O 

Ports 



The Intel® 8243 is an input/output expander designed specifically to provide a low cost means of I/O expansion for tlie 
MCS-48^" family of single chip microcomputers. Fabricated in 5 volts NMOS, the 8243 combines low cost, single supply 
voltage and high drive current capability. 

The 8243 consists of four 4-bit bidirectional static I/O ports and one 4-bit port which serves as an interface to the MCS-48 
microcomputers. The 4-bit interface requires that only 4 I/O lines of the 8048 be used for I/O expansion, and also allows 
multiple 8243's to be added to the same bus. 

The I/O ports of the 8243 serve as a direct extension of the resident I/O facilities of the MCS-48 microcomputers and are 
accessed by their own MOV, ANL, and ORL instructions. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



4 > PORT 4 



P50C 


1 ^ 


■^ 24 


HVcc 


P40E 


2 


23 


I]P51 


P4lC 


3 


22 


DP52 


P42C 


4 


21 


DP53 


P43C 


5 


20 


DP60 


CSC 


6 82A-* '^ 


DP61 


progC 


7 


18 


DP62 


P23C 


8 


17 


I3P63 


P22C 


9 


16 


DP73 


P21[: 


10 


15 


DP72 


P20C 


11 


14 


DP71 


gndC 


12 


13 


DP70 
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PIN DESCRIPTION 



Symbol 



Pin No. 



Function 



PROG 



CS 



P20-P23 



GND 



P40-P43 


2-5 


P50-P53 


1,23-21 


P60-P63 


20-17 


P70-P73 


13-16 



^CC 



7 Clock Input. A high to low 

transistion on PROG signifies 
that address and control are 
available on P20-P23, and a low 
to high transition signifies that 
data is available on P20-23. 

6 Chip Select Input. A high on CS 

inhibits any change of output or 
internal status. 

11-8 Four (4) bit bi-directional port 
contains the address and con- 
trol bits on a high to low 
transition of PROG. During a 
low to high transition contains 
the data for a selected output 
port if a write operation, or the 
data from a selected port before 
the low to high transition if a 
read operation. 

12 volt supply. 

Four (4) bit bi-directional I/O 
ports. May be programmed 
to be input (during read), 
low impedance latched output 
(after write) or a tri-state (after 
read). Data on pins P20-23 may 
be directly written, ANDed or 
ORed with previous data. 

24 +5 volt supply. 



FUNCTIONAL DESCRIPTION 
General Operation 

The 8243 contains four 4-bit I/O ports which serve as an 
extension of the on-chip I/O and are addressed as ports 4- 
7. The following operations may be performed on these 
ports: 

• Transfer Accumulator to Port. 

• Transfer Port to Accumulator. 

• AND Accumulator to Port. 

• OR Accumulator to Port. 

All communication between the 8048 and the 8243 occurs 
over Port 2 (P20-P23) with timing provided by an output 
pulse on the PROG pin of the processor. Each transfer 
consists of two 4-bit nibbles: 

The first containing the "op code" and port address and 
the second containing the actual 4-bits of data. 



A high to low transition of the PROG line indicates that 
address is present while a low to high transition indicates 
the presence of data. Additional 8243's may be added to 
the 4-bit bus and chip selected using additional output 
lines from the 8048/8748/8035. 

Power On initialization 

Initial application of power to the device forces 
input/output ports 4, 5, 6, and 7 to the tri-state and port 2 to 
the input mode. The PROG pin may be either high or low 
when power is applied. The first high to low transition of 
PROG causes device to exit power on mode. The power on 
sequence is initiated if Vqc drops below IV. 



P21 P20 


Address Code 


P23 


P22 Instruction Code 




1 

1 

1 1 




Port 4 
Port 5 
Port 6 
Port 7 





1 
1 


Read 

1 Write 

ORLD 

1 ANLD 


Write Modes 









The device has three write modes. MOVD Pi, A directly 
writes new data into the selected port and old data is lost. 
ORLD Pi, A takes new data, OR's it with the old data and 
then writes it to the port. ANLD Pi, A takes new data AND's 
it with the old data and then writes it to the port. Operation 
code and port address are latched from the input port 2 on 
the high to low transition of the PROG pin. On the low to 
high transition of PROG data on port 2 is transferred to the 
logic block of the specified output port. 

After the logic manipulation is performed, the data is 
latched and outputed. The old data remains latched until 
new valid outputs are entered. 

Read IVIode 

The device has one read mode. The operation code and 
port address are latched from the input port 2 on the high 
to low transition of the PROG pin. As soon as the read 
operation and port address are decoded, the appropriate 
outputs are tri-stated, and the input buffers switched on. 
The read operation is terminated by a low to high 
transition of the PROG pin. The port (4, 5, 6 or 7) that was 
selected is switched to the tri-stated mode while port 2 is 
returned to the input mode. 

Normally, a port will be In an output (write mode) orinput 
(read mode). If modes are changed during operation, the 
first read following a write should be ignored; all follow- 
ing reads are valid. This Is to allow the external driver on 
the port to settle after the first read instruction removes 
the low impedance drive from the 8243 output. A read of 
any port will leave that port in a high impedance state. 
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ABSOLUTE MAXIMUM RATINGS* 



Ambient Temperature Under Bias 0"C to 70''C 

Storage Temperature -65*^0 to +150'C 

Voltage on Any Pin 

With Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



^COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. AND OPERATING CHARACTERISTICS 

Ta = 0°Cto 70°C, Vcc = 5V ±10% 



SYMBOL 


PARAMETER 


MIN. 


TYP. 


MAX. 


UNITS 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-0.5 




0.8 


V 




V|H 


Input High Voltage 


2.0 




Vcc+0.5 


V 




VOLI 


Output Low Voltage Ports 4-7 






0.45 


V 


l0L=5mA* 


V0L2 


Output Low Voltage Port 7 






1 


V 


Iql = 20 mA 


VOHI 


Output High Voltage Ports 4-7 


2.4 






V 


Ioh=240axA 


l|L1 


Input Leakage Ports 4-7 


-10 




20 


/ja 


Vin = Vcc to OV 


«IL2 


Input Leakage Port 2, OS, PROG 


-10 




10 


AiA 


Vin = Vcc to OV 


V0L3 


Output Low Voltage Port 2 






.45 


V 


IOL=0-6 mA 


'cc 


Vcc Supply Current 




10 


20 


mA 




V0H2 


Output Voltage Port 2 


2.4 








IOH=100iuA 


•OL 


Sum of all IOl from 16 Outputs 






80 


mA 


5 mA Each Pin 



*See following graph for additional sink current capability 



A.C. CHARACTERISTICS 



Ta =0°Cto70°C, V, 



CC 



5V±10% 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


tA 


Code Valid Before PROG 


100 




ns 


80 pF Load 


tB 


Code Valid After PROG 


60 




ns 


20 pF Load 


to 


Data Valid Before PROG 


200 




ns 


80 pF Load 


tD 


Data Valid After PROG 


20 




ns 


20 pF Load 


tH 


Floating After PROG 





150 


ns 


20 pF Load 


tK 


PROG Negative Pulse Width 


700 




ns 




tcs 


CS Valid Before/After PROG 


50 




ns 




tpo 


Ports 4-7 Valid After PROG 




700 


ns 


100 pF Load 


tLPI 


Ports 4-7 Valid Before/After PROG 


100 




ns 




tACC 


Port 2 Valid After PROG 




650 


ns 


80 pF Load 
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WAVEFORMS 



K 



/ 



-etg-^ 



"V V s/ V 

X INSTRUCTION V FLOAT V DATA X 

A A A A 



Xy' OUTPUT \X 

A °-° A 



PREVIOUS OUTPUT VALID 



t|P 



X 



INPUT VALID 



-*-tcs -► 



CS 



^. 



X 



OUTPUT 
VALID 



x: 
y 
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125 



< 




E 








^«^ 


100 


J 




o 




w 




K 


75 


Z 




LU 




cc 




cc 




D 

o 


50 


:^ 




z 




00 




u 




< 


25 


K- 




O 





GUARANTEED WORST CASE 
CURRENT SINKING 
CAPABILITIES OF ANY I/O 
PORT PIN vs. TOTAL SINK 
CURRENT OF ALL PINS 



_L 



_L 



X 



8 



10 11 12 13 



MAXIMUM SINK CURRENT ON ANY PIN@.45V 
MAXIMUM loL WORST CASE PIN (mA) 



Sink Capability 

The 8243 can sink 5 mA@.45V on each of its 16 I/O lines 
simultaneously. If, however, all lines are not sinking 
simultaneously or all lines are not fully loaded, the drive 
capability of any individual line increases as is shown by 
the accompanying curve. 

For example, if only 5 of the 16 lines are to sink current 
at one time, the curve shows that each of those 5 lines is 
capable of sinking 9 mA@.45V (if any lines are to sink 
9 mA the total Iql must not exceed 45 mA or five 9 mA 
loads). 

Example: How many pins can drive 5 TTL loads (1.6 mA) 
assuming remaining pins are unloaded? 

loL=5 X 1.6 mA = 8 mA 
£loL=60 mA from curve 
# pins = 60 mA ^ 8 mA/pin = 7.5 = 7 

In this case, 7 lines can sink 8 mA for a total 
of 56 mA. This leaves 4 mA sink current capa- 
bility which can be divided in any way among 
the remaining 8 I/O lines of the 8243. 



Example: This example shows how the use of the 20 
mA sink capability of Port 7 affects the sink- 
ing capability of the other I/O lines. 



An 8243 will drive the following loads simul- 
taneously. 



2 loads — 20 mA@ 1 V (port 7 only) 

8 loads — 4 mA@.45V 

6 loads — 3.2 mA@.45V 

Is this within the specified limits? 



£loL=(2 X 20)-*- (8 X 4) + (6 X 3.2) = 91.2 mA. 
From the curve: for Iol= 4 mA, cIql ~ 93 mA 
since 91.2 mA < 93 mA the loads are within 
specified limits. 



Although the 20 mA@1V loads are used in 
calculating eIqi* 't 'S the largest current re- 
quired@.45V which determines the maximum 
allowable eIql- 



Note: A 10 to 50Kn puHup resistor to -H5V should be added to 8243 outputs when driving to 5V CMOS directly. 
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EXPANDER INTERFACE 



OO' 



8048 



c 



c 



^ 



H 



8243 






OUTPUT EXPANDER TIMING 



\ 



y 



-CIDC 



ADDRESS (4-BITS) DATA (4-BITS) 



00 n READ 00 

01 L WRITE 01 
10 r OR 10 
nj AND 11 



00 n 

L PORT 
10 r ADDRESS 



CO 
CO 



PROG P20-3 






PROG P20-3 



TF 



<x> 

CO 



PROG P20-3 



CO 



"7n 



CO 

CO 

ioO 



USING MULTIPLE 8243's 



7-16 



Intel 



8292 
GPIB CONTROLLER 



Complete IEEE Standard 488 Controller 
Function 

Interface Clear (IFC) Sending Capability 
Allows Seizure of Bus Control and/or 
Initialization of the Bus 

Responds to Service Requests (SRQ) 

Sends Remote Enable (REN), Allowing 
Instruments to Switch to Remote 
Control 



Complete Implementation of Transfer 
Control Protocol 

Synchronous Control Seizure Prevents 
the Destruction of Any Data 
Transmission in Progress 

Connects with the 8291 to Form a 
Complete IEEE Standard 488 Interface 
Talker/Listener/Controller 



The 8292 GPIB Controller is a microprocessor-controlled chip designed to function with the 8291 GPIB Talker/Listener 
to implement the full IEEE Standard 488 controller function, including transfer control protocol. The 8292 is a pre- 
programmed Intel® 8041A. 



PIN CONFIGURATION 



IFCL L 


1 ^ 


^ 40 


I! vcc 


xiC 


2 


39 


H 


COUNT 


X2C 


3 


38 


3 


REN 


RESET L 


4 


37 


D 


DAV 


VccC 


5 


36 


3 


IBFi 


csC 


6 


35 


3 


OBFI 


GND H 


7 


34 


3 


EOT 


rdC 


8 


33 


3 


SPI 


AoC 


9 


32 


3 


TCI 


wrC 


10 '^'^ 31 


II 


cic 


SYNC C 


11 


30 


H 


NC 


DoE 


12 


29 


H 


ATNO 


D1C 


13 


28 


n 


NC 


D2C 


14 


27 


3 


CLTH 


D3C 


15 


26 


3 


Vcc 


D4C 


16 


25 


3 


NC 


D5C 


17 


24 


3 


SYC 


Dec 


18 


23 


3 


iFC 


D7C 


19 


22 


3 


ATNI 


vssC 


20 


21 


H 


SRQ 



8291, 8292 SYSTEM DIAGRAM 



MICROPROCESSOR SYSTEM BUS 



r ^^ ! BACK I ^""^ 



I 

I DMA 

I CONTROLLER 

I (OPTIONAL) 



8291 

GPIB 
TALKER/ 
LISTENER 



:sz: 



BUS 
TRANSCEIVERS 



■2^ 




GENERAL PURPOSE INTERFACE BUS 



7-17 



8292 



PIN DESCRIPTION 



Symbol 


I/O 


Pin No. 


Function 


IFCL 


1 


1 


IFC Received (latched) - The 8292 
monitors the IFC Line (when not 
system controller) through this 
pin. 


Xi,X2 


1 


2,3 


Inputs for a crystal, LC or an exter- 
nal timing signal to determine the 
internal oscillator frequency. 


RESET 


1 


4 


Used to initialize the chip to a 
known state during power on. 


CS 


1 


6 


Chip Select Input — Used to select 
the 8292 from other devices on the 
common data bus. 


RD 


1 


8 


I/O write input which allows the 
master CPU to read from the 8292. 


Ao 


1 


9 


Address Line — Used to select be- 
tween the data bus and the status 
register during read operations 
and to distinguish between data 
and commands written into the 
8292 during write operations. 


WR 


1 


10 


I/O read input which allows the 
master CPU to write to the 8292. 


SYNC 





11 


8041A instruction cycle synchro- 
nization signal; it is an output 
clock with a frequency of 
XTAL^IS. 


D0-D7 


I/O 


12-19 


8 bidirectional lines used for com- 
munication between the central 
processor and the 8292's data bus 
buffers and status register. 


Vss 


P.S. 


7,20 


Circuit ground potential. 


SRQ 


1 


21 


Service Request — One of the 
IEEE control lines. Sampled by the 
8292 when it is controller in 
charge. If true, SPI interrupt to the 
master will be generated. 


ATNI 


1 


22 


Attention In — Used by the 8292 to 
monitor the GPIB ATN control 
line. It is used during the transfer 
control procedure. 


IFC 


I/O 


23 


Interface Clear — One of the GPIB 
management lines, as defined by 
IEEE Std. 488-1978, places all de- 
vices in a known quiescent state. 


SYC 


1 


24 


System Controller — Monitors the 
system controller switch. 


CLTH 





27 


CLEAR LATCH Output — Used to 
clear the IFOR latch after being 
recognized by the 8292. Usually 
low (except after hardware Reset), 
it will be pulsed high when IFCR is 
recognized by the 8292. 


ATNU 





29 


Attention Out — Controls the ATN 
control line of the bus through ex- 
ternal logic for tcs and tea pro- 
cedures. (ATN is a GPIB control 
line, as defined by IEEE Std. 
488-1978.) 



Symbol 


I/O 


Pin No. 


Function 


Vcc 


P.S. 


5, 26, 40 


-I-5V supply input. ±10%. 


COUNT 


1 


39 


Count Input — When enabled by 
the proper command the Internal 
counter will count external events 
through this pin. High to low tran- 
sition will increment the internal 
counter by one. The pin is sampled 
once per three internal instruction 
cycles (7.5 ^sec sample period 
when using 6 MHz XTAL). It can be 
used for byte counting when con- 
nected to NDAC, or for block 
counting when connected to the 
EOl. 


REN 





38 


The Remote Enable bus signal 
selects remote or local control of 
the device on the bus. A GPIB bus 
management line, as defined by 
IEEE Std. 488-1978. 


DAV 


I/O 


37 


DAV Handshake Line — Used dur- 
ing parallel poll to force the 8291 
to accept the parallel poll status 
bits. It is also used during the tcs 
procedure. 


IBFI 





36 


Input Buffer Not Full — Used to 
interrupt the central processor 
while the input buffer of the 8292 
is empty. This feature is enabled 
and disabled by the interrupt 
mask register. 


OBFI 





35 


Output Buffer Full — Used as an 
interrupt to the central processor 
while the output buffer of the 8292 
is full. The feature can be enabled 
and disabled by the interrupt 
mask register. 


E0I2 


I/O 


34 


End Or Identify — One of the GPIB 
management lines, as defined by 
IEEE Std. 488-1978. Used with ATN 
as Identify Message during paral- 
lel poll. 


SPI 





33 


Special Interrupt — Used as an 
interrupt on events not initiated by 
the central processor. 


TCI 





32 


Task Complete Interrupt — Inter- 
rupt to the control processor used 
to indicate that the task requested 
was completed by the 8292 and 
the information requested is ready 
in the data bus buffer. 


CIC 





31 


Controller In Charge — Controls 
the S/R input of the SRQ bus 
transceiver. It can also be used to 
indicate that the 8292 is in charge 
of the GPIB bus. 
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GENERAL DESCRIPTION 

The 8292 Is an Intel 8041A which has been programmed 
as a GPIB Controller Interface element. It is used with 
the 8291 GPIB Talker/Listener and two 8293 GPIB Trans- 
ceivers to form a complete IEEE-488 Bus Interface for a 
microprocessor. The electrical Interface is performed by 
the transceivers, data transfer is done by the talker/ 
listener, and control of the bus is done by the 8292. 
Figure 1 is a typical controller Interface using Intel's 
GPIB peripherals. 



Interrupt Status Register 



TO y1_ 

PROCESSOR ( 19 
BUS\|^ 



T0/_ 

PROCESSOR ( 15 

BUS\"^ 



OPTA 
OPTB 
8293 






^ 




Figure 1. Taiker/Listener/Controlier Configuration 



The internal RAM in the 8041 A is used as a special 
purpose register bank for the 8292. Most of these 
registers (except for the interrupt flag) can be accessed 
through commands to the 8292. Table 1 identifies the 
registers used by the 8292 and how they are accessed. 



SYC 


ERR 


SRQ 


EV 


X 


IFOR 


IBF 


OBF 



D7 Do 

The 8292 can be configured to interrupt the microproc- 
essor on one of several conditions. Upon receipt of the 
interrupt the microprocessor must read the 8292 
Interrupt status register to determine which event 
caused the interrupt, and then the appropriate subrou- 
tine can be performed. The interrupt status register is 
read with Aq high. With the exception of OBF and IBF, 
these interrupts are enabled or disabled by the SPI 
interrupt mask. OBF and IBF h ave their own bits in the 
Interrupt mask (OBFI and IBFI). 

OBF Output Buffer Full. A byte is waiting to be read by 
the microprocessor. This flag is cleared when the 
output data bus buffer is read. 

iBF Input Buffer Full. The byte previously written by 
the microprocessor has not been read yet by the 
8292. If another byte is written to the 8292 before 
this flag clears, data will be lost. IBF is cleared 
when the 8292 reads the data byte. 

IFCR Interface Clear Received. The GPIB system 
controller has set IFC. The 8292 has become idle 
and is no longer in charge of the bus. The flag Is 
cleared when the lACK command Is issued. 

EV Event Counter Interrupt. The requested number 
of blocks or data bytes has been transferred. The 
EV interrupt flag is cleared by the lACK 
command. 

SRQ Service Request. Notifies the 8292 that a service 
request (SRQ) message has been received. It is 
cleared by the lACK command. 

ERR Error occurred. The type of error can be deter- 
mined by reading the error status register. This 
Interrupt flag is cleared by the lACK command. 

SYC System Controller Switch Change. Notifies the 
processor that the state of the system controller 
switch has changed. The actual state is con- 
tained in the GPIB Status Register. This flag is 
cleared by the lACK command. 



TABLE 1. 8292 REGISTERS. 
READ FROM 8292 

INTERRUPT STATUS 



WRITE TO 8292 



SYC 


ERR 


SRQ 


EV 


X 


IFCR 


IBF 


OBF 


D7 






ERROR FLAG 




Do 


X 


X 


USER 


X 


X 


TOUT3 


TOUT2 


TOUT1 


CONTROLLER STATUS 


CSBS 


CA 


X 


X 


SYCS 


IFC 


REN 


SRQ 


GPIB (BUS) STATUS 


REN 


DAV 


EOl 


X 


SYC 


IFC 


ANTI 


SRQ 


EVENT COUNTER STATUS 


D 


D 


D 


D 


D 


D 


D 


D 


TIME OUT STATUS 


D 


D 


D 


D 





D 


D 


D 



INTERRUPT MASK 



1 


SPI 


TCI 


SYC 


OBFI 


IBFI 





SRQ 


D7 






ERROR MASK 




Do 








USER 








TOUT3 


TOUT2 


TOUT^ 


COMMAND FIELD 


1 


1 


1 


OP 


C 


C 


C 


C 


EVENT COUNTER 


D 


D 


D 


D 


D 


D 


D 


D 


TIME OUT 


D 


D 


D 


D 


D 


D 


D 


D 



Ao 



Note: These registers are accessed by a special utility command, 
see page 6. 
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Interrupt Mask Register 



Event Counter Register 



1 


SPI 


TCI 


SYC 


OBFI 


IBFI 





SRQ 




D7 


De 


D5 


D4 


D3 


D2 


Dl 


Do 



Dy 



Do 



The Interrupt Mask Register is used to enabie features 
and to masl< tlie SPI and TCI interrupts. The flags in the 
Interrupt Status Register will be active even when 
masked out. The Interrupt Mask Register is written 
when Aq is low and reset by the RINM command. When 
the register is read, Di and D7 are undefined. An inter- 
tupt is enabled by setting the corresponding register bit. 

SRQ Enable interrupts on SRQ received. 

IBFI Enable interrupts on input buffer empty. 

OBFI Enable interrupts on output buffer full. 

SYC Enable interrupts on a change in the system 
controller switch. 

TCI Enable interrupts on the task completed. 

SPI Enable interrupts on special events. 

NOTE: The event counter is enabled by the GSEC 
command, the error interrupt is enabled by the error 
mask register, and IPC cannot be masked (it will always 
cause an interrupt). 

Controller Status Register 



The Event Counter Register contains the initial value for 
the event counter. The counter can count pulses on pin 
39 of the 8292 (COUNT). It can be connected to EOl or 
NDAC to count blocks or bytes respectively during 
standby state. A count of zero equals 256. This register 
cannot be read, and is written using the WEVC 
command. 



Event Counter Status Register 



D7 


D6 


D5 


D4 


D3 


D2 


D1 


Do 



This register contains the current value in the event 
counter. The event counter counts back from the initial 
value stored In the Event Counter Register to zero and 
then generates an Event Counter Interrupt. This register 
cannot be written and can be read using a REVC 
command. 

Time Out Register 



D7 


De 


D5 


D4 


D3 


D2 


D1 


Do 



CSBS 


CA 


X 


X 


SYCS 


IFC 


REN 


SRQ 



D? Do 

The Controller Status Register is used to determine the 
status of the controller function. This register is 
accessed by the RCST command. 

SRQ Service Request line active (CSRS). 

REN Sending Remote Enable. 

IFC Sending or receiving interface clear. 

SYCS System Controller Switch Status (SACS). 

CA Controller Active (CACS + CAWS + CSWS). 

CSBS Controller Stand-by State (CSBS, CA) = (0,0) — 
Controller Idle 



The Time Out Register is used to store the time used for 
the time out error function. See the individual timeouts 
(T0UT1, 2, 3) to determine the units of this counter. This 
Time Out Register cannot be read, and it is written with 
the WTOUT command. 

Time Out Status Register 



D7 


De 


D5 


D4 


D3 


D2 


D1 


Do 



This register contains the current value in the time out 
counter. The time out counter decrements from the 
original value stored in the Time Out Register. When 
zero is reached, the appropriate error interrupt is gen- 
erated. If the register is read while none of the time out 
functions are active, the register will contain the last 
value reached the last time a function was active. The 
Time Out Status Register cannot be written, and it is 
read with the RTOUT command. 



GPIB Bus Status Register 










Error Flag Register 
















X 


X 


USER 


X 


X 


TOUT3 


TOUT2 


TOUT1 


REN 


DAV 


EOl 


X 


SYC 


IFC 


ATNI 


SRQ 






D7 














Do 



D7 Do 

This register contains GPIB bus status information. It 
can be used by the microprocessor to monitor and 
manage the bus. The GPIB Bus Register can be read 
using the RBST command. 

Each of these status bits reflect the current status of 
the corresponding pin on the 8292. 

SRQ Service Request 

ATNI Attention In 

IFC Interface Clear 

SYC System Controller Switch 

EOl End or Identify 

DAV Data Valid 

REN Remote Enable 



Four errors are flagged by the 8292 with a bit in the Error 
Flag Register. Each of these errors can be masked by 
the Error Mask Register. The Error Flag Register cannot 
be written, and it is read by the JACK command when the 
error flag in the Interrupt Status Register is set. 

T0UT1 Time Out Error 1 occurs when the current con- 
troller has not stopped sending ATN after 
receiving the TOT message for the time period 
specified by the Time Out Register. Each count 
in the Time Out Register is at least 1800 tcy- 
After flagging the error, the 8292 will remain in a 
loop trying to take control until the current 
controller stops sending ATN or a new com- 
mand is written by the microprocessor. If a new 
command is written, the 8292 will return to the 
loop after executing it. 
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T0UT2 Time Out Error 2 occurs when the transmission 
between the addressed talker and listener has 
not started for the time period specified by the 
Time Out Register. Each count in the Time Out 
Register is at least 45 tcv- This feature is only 
enabled when the controller is in the CSBS 
state. 

T0UT3 Time Out Error 3 occurs when the handshake 
signals are stuck and the 8292 is not succeed- 
ing in taking control synchronously for the time 
period specified by the Time Out Register. Each 
count in the Time Out Register is at least 1800 
tcY- The 8292 will continue checking ATNI until 
it becomes true or a new command is received. 
After performing the n ew command, the 8292 
will return to the ATNI checking loop. 

USER User error occurs when request to assert IFG or 
REN was received and the 8292 was not the 
system controller. 

Error Mask Register 









USER 








TOUT3 


TOUT2 


TOUT1 



Do 



The Error Mask Register is used to mask the interrupt 
from a particular type of error. Each type of error inter- 
rupt Is enabled by setting the corresponding bit in the 
Error Mask Register. This register can be read with the 
RERM command and written with Aq low. 



Command Register 



1 


1 


1 


OP 








c 


c 



Do 



Commands are performed by the 8292 whenever a byte 
is written with Aq high. There are two categories of 
commands distinguished by the OP bit (bit 4). The first 
category is the operation command (0P=1). These 
commands initiate some action on the interface bus. 
The second category is the utility commands (OP = 0). 
These commands are used to aid the communication 
between the processor and the 8292. 



OPERATION COMMANDS 

Operation commands initiate some action on the GPIB 
interface bus. It Is using these commands that the 
control functions such as polling, taking and passing 
control, and system controller functions are performed. 
A TCI interrupt is generated upon successful comple- 
tion of each of these functions. 

FO -^ SPCNi — Stop Counter interrupts 

This command disables the internal counter Interrupt so 
that the 8292 will stop interrupting the master on event 
counter underflows. However, the counter will continue 
counting and its contents can still be used. 



F1 - GiDL - Go To idie 

This command is used during the transfer of control 
procedure while transferring control to another con- 
troller. The 8292 will respond to this command only if it 
is in the active state. ATNO will go high, and CIC will be 
high so that this 8292 will no longer be driving the ATN 
line on the GPIB interface bus. 

F2 — RST — Reset 

This command has the same effect as asserting the 
external reset on the 8292. For details, refer to the reset 
procedure described later. 

F3 — RSTi ^ Reset interrupts 

This command resets any pending interrupts and clears 
the error flags. The 8292 will not return to any loop it was 
in (such as from the time out interrupts). 

F4 ~ GSEC — Go To Standby, Enabie Counting 

The function causes ATNO to go high and the counter 
will be enabled. If the 8292 was not the active controller, 
this command will exit immediately. If the 8292 is the 
active controller, the counter will be loaded with the 
value stored in the Event Counter Register, and the 
internal interrupt will be enabled so that when the 
counter reaches zero, the SPI interrupt will be gener- 
ated. SPI will be generated every 256 counts thereafter 
until the controller exits the standby state or the SPCNI 
command is written. An initial count of 256 (zero In the 
Event Counter Register) will be used if the WEVC 
command is not executed. If the data transmission does 
not start, a T0UT2 error will be generated. 

F5 - EXPP - Execute Paraiiei Poii 

This command initiates a parallel poll by asserting ATN 
and EOl (IDY message) true. The 8291 should be 
previously configured as a listener. Upon detection of 
DAV true, the 8291 enters ACDS and latches the parallel 
poll response (PPR) byte Into its data in register. The 
master will be interrupted by the 8291 Bl interrupt when 
the PPR byte is available. No Interrupts except the IBFI 
will be generated by the 8292. The 8292 will respond to 
this command only when it is the active controller. 

F6 — GTSB — Go To Standby 

If the 8292 is the active controller, ATNO will go high 
then TCI will be generated. If the data transmission does 
not start, a T0UT2 error will be generated. 

F7 — SLOC — Set Locai l^/iode 

If the 8292 is the system controller, then REN will be 
asserted false for at least 100 ptsec. If It is not the 
system controller, the User Error bit will be set In the 
Error Flag Register. 

F8 — SREIVI — Set interface To Remote Controi 

This command will set REN true If this 8292 Is the 
system controller. 1f not, the User Error bit will be set In 
the Error Flag Register. 
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F9 " ABORT — Abort All Operation, Clear Interface 

This command will cause iFC to be asserted true for at 
least 100 jisec if tills 8292 is tlie system controller. If it is 
in CIDS, it will take control over the bus (see the TCNTR 
command). 

FA - TCNTR - Take Control 

The transfer of control procedure is coordinated by the 
master with the 8291 and 8292. When the master 
receives a TOT message from the 8291, it should issue 
the TCNTR command to the 8292. The following events 
occur to tal<e control: 

1. The 8292 checks to see if it is in CIDS, and if not, it 
exits. 

2. Then ATNI is checked until it becomes high. If the 
current controller does not release ATN for the time 
specified by the Time Out Register, then a T0UT1 
error is generated. The 8292 will return to this loop 
after an error or any command except the RST and 
RSTi commands. 

3. After the current controller releases ATN, the 8292 
will assert ATNO and CIC low. 

4. Finally, the TCI interrupt is generated to inform the 
master that it is in control of the bus. 

FC — TCASY — Take Control Asynchronously 

TCAS transfers the 8292 from CSBS to CACS indepen- 
dent of the handshake lines. If a bus hangup is detected 
(by an error flag), this command will force the 8292 to 
take control (asserting ATN) even if the AH function is 
not in ANRS (Acceptor Not Ready State). This command 
should be used very carefully since it may cause the 
loss of a data byte. Normally, control should be taken 
synchronously. After checking the controller function 
for be ing in the CSBS (else it will exit immediately), 
ATNO will go low, and a TCI interrupt will be generated. 

FD — TCSY — Take Control Synchronously 

There are two different procedures used to transfer the 
8292 from CSBS to CACS depending on the state of the 
8291 in the system. If the 8291 is in "continuous AH 
cycling" mode (Aux. Reg. A0 = A1 = 1), then the 
following procedure should be followed: 

1. The master microprocessor stops the continuous AH 
cycling mode in the 8291; 

2. The master reads the 8291 Interrupt Status 1 
Register; 

3. If the END bit is set, the master sends the TCSY 
command to the 8292; 

4. If the END bit was not set, the master reads the 8291 
Data In Register and then waits for another Bl 
interrupt from the 8291. When it occurs, the master 
sends the 8292 the TCSY command. 

If the 8291 is not in AH cycling mode, then the master 
just waits for a Bl interrupt and then sends the TCSY 
command. After the TCSY co mmand has been issued, 
the 8292 checks for CSBS. If CSBS, then it exits the 
routine. Otherwise, it then checks the DAV bit in the 
GPIB status. When DAV becomes false, the 8292 will 



wait for at least 1.5 pisec. (T10) and then ATNO will go 
low. If DAV does not go low, a T0UT3 error will be 
generated. 

FE — STCNI — Start Counter Interrupts 

This command enables the internal counter interrupt. 
The counter is enabled by the GSEC command. 



UTILITY COMMANDS 

All these commands are either Read or Write to regis- 
ters in the 8292. Upon completion of Read commands, 
the TCI (Task Completed Interrupt) will be generated. 
Note that writing to the Error IVIask Register and the 
Interrupt Mask Register are done directly. 

E1 — WTOUT — Write To Time Out Register 

The byte written to the data bus buffer (with Ao=0) 
following this command will determine the time used 
for the time out function. Since this function is imple- 
mented in software, this will not be an accurate time 
measurement. This feature is enable or disable b y the 
Error Mask Register. No interrupts except for the IBFI 
will be generated upon completion. 

E2 - WEVC - Write To Event Counter 

The byte written to the data bus buffer (with Ao = 0) 
following this command will be loaded into the Event 
Counter Register and the Event Cou nter Status for byte 
counting or EOl counting. Only IBFI will indicate 
completion of this command. 

E3 — REVC — Read Event Counter Status 

This command transfers the contents of the Event 
Counter into the data bus buffer. A TCI is generated 
when the data is available in the data bus buffer. 

E4 — RERF — Read Error Flag Register 

This command transfers the contents of the Error Flag 
Register into the data bus buffer. A TCI is generated 
when the data is available. 

E5 — RINM — Read Interrupt Mask Register 

This command transfers the contents of the Interrupt 
Mask Register into the data bus buffer. This register is 
available to the processor so that it does not need to 
store this information elsewhere. A TCI is generated 
when the data is available in the data bus buffer. 

E6 — RCST — Read Controller Status Register 

This command transfers the contents of the Controller 
Status Register into the data bus buffer and a TCI inter- 
rupt is generated. 

E7 — RBST — Read GPIB Bus Status Register 

This command transfers the contents of the GPIB Bus 
Status Register into the data bus buffer, and a TCi 
interrupt is generated when the data is available. 
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E9 — RTOUT — Read Time Out Status Register 

This command transfers the contents of the Time Out 
Status Register into the data bus buffer, and a TCI 
interrupt is generated when the data is available. 

EA — RERfA — Read Error IViasIc Register 

This command transfers the contents of the Error Mask 
Register to the data bus buffer so that the processor 
does not need to store this information elsewhere. A TCI 
interrupt is generated when the data is available. 

Interrupt Aclcnowiedge 



SYC 


ERR 


SRQ 


EV 


1 


IFCR 


1 


1 



D7 



Do 



Each named bit in an Interrupt Acknowledge (lACK) 
corresponds to a flag in the Interrupt Status Register. 
When the 8292 receives this command, it will clear the 
SPI and the corresponding bits in the Interrupt Status 
Register. If not all the bits were cleared, then the SPI will 
be set true again. If the error flag is not acknowledged 
by the lACK command, then the Error Flag Register will 
be transferred to the data bus buffer, and a TCI will be 
generated. 

NOTE: XXXX1X11 is an undefined operation or utility 
command, so no conflict exists between the lACK 
operation and utility commands. 



SYSTEM OPERATION 

8292 To Master Processor Interface 

Communication between the 8292 and the Master 
Processor can be either interrupt based communication 
or based upon polling the interrupt status register in 
predetermined intervals. 

Interrupt Based Communication 

Four different interrupts are available from the 8292: 
OBFI Output Buffer Full Interrupt 
IBFi Input Buffer Not Full Interrupt 
TCI Task Completed Interrupt 
SPI Special Interrupt 

Each of the interrupts is enabled or disabled b y a b it in 
the interrupt mask register. Since OBFI and IBFI are 
directly connected to the OBF and IBF flags, the master 
can write a new command to the input data bus buffer 
as soon as the previous command has been read. 

The TCI interrupt is useful when the master is sending 
commands to the 8292. The pending TCI will be cleared 
with each new command written to the 8292. Commands 
sent to the 8292 can be divided into two major groups: 

1. Commands that require response back from the 8292 
to the master, e.g., reading register. 

2. Commands that initiate some action or enable 
features but do not require response back from the 
8292, e.g., enable data bus buffer interrupts. 



With the first group, the TCI Interrupt will be used to 
indicate that the required response is ready in the data 
bus buffer and the master may continue and read it. 
With the second group, the interrupt will be used to 
indicate completion of the required task, so that the 
master may send new commands. 

The SPI should be used when immediate information or 
special events is required (see the Interrupt Status 
Register). 

"Polling Status" Based Communication 

When interrupt based communication is not desired, all 
interrupts can be masked by the interrupt mask register. 
The communication with the 8292 is based upon 
sequential poll of the interrupt status register. By 
testing the OBF and IBF flags, the data bus buffer 
status is determined while special events are deter- 
mined by testing the other bits. 

Receiving IPC 

The IFC pulse defined by the IEEE-488 standard is at 
least 100 pisec. In this time, all operation on the bus 
should be aborted. Most important, the current control- 
ler (the one that is in charge at that time) should stop 
sending ATN or EOl. Thus, I FC mu st externally gate CIC 
(controller in charge) and ATNO to ensure that this 
occurs. 

Reset and Power Up Procedure 

After the 8292 has been reset either by the external reset 
pin, the device being powered on, or a RST command, 
the following sequential events will take place: 

1. All ou tputs to the GPIB i nterfa c e wi ll go high ( SRQ , 
ATNI, IFC, SYC, CLT H, ATNO, CIC, TCI, SPI, EOl, 
OBFI, iBFf, DAV, REV). 

2. The four interrupt outputs (TCI, SPI, OBFI, IBFI) and 
CLTH output will go low. 

3. The following registers will be cleared: 
Interrupt Status 

Interrupt Mask 

Error Flag 

Error Mask 

Time Out 

Event Counter (=256), Counter is disabled. 

4. If the 8292 is the system controller, an ABORT 
command will be executed, the 8292 will become the 
controller in charge, and it will enter the CACS state. 

If it Is not the system controller, it will remain in 
CIDS. 

System Configuration 

The 8291 and 8292 must be Interfaced to an IEEE-488 
bus meeting a variety of specifications including drive 
capability and loading characteristics. To interface the 
8291 and the 8292 without the 8293's, several external 
gates are required, using a configuration similar to that 
used in Figure 3. 
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PROCESSOR BUS 

INTERRUPT WR RD RST CLK ADD DATA DMA 

i\ k I, 



Y 



nn 



NOTES: 

1. CONNECT TO NDAC FOR 
BYTE COUNT OR TO EOl 
FOR BLOCK COUNT. 

2. GATE ENSURES OPEN 
COLLECTOR OPERATION 
DURING PARALLEL POLL. 



JT 



T_ 



DREQ 

DACK 

DATA 

RSo 

RSi 

RS2 

CLOCK 

RESET 

RD 

WR 

INT 

CS 



Ao 
CS 

RD 
WR 
RESET 



T/R2 



T/ffi 



^ 
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ff 



5 
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-i->- 






I 
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3d I NRFD 



fe] 



on 



59' 
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Figure 2. 8291 and 8292 System Configuration 
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TO 
MICROPROCESSOR 



GPIB 
TRIGGER • 
OUTPUT 



^>- 



TO 
MICROPROCESSOR 



OSCILLATOR 
OUTPUT 



DO 

D1 

D2 

D3 

D4 

D5 

D6 

D7 

RSO 

RS1 

RS2 

RD 

WR 

RESET 

DREQ 

DACK 

CS 

CLOCK 

INT 



15-25 PF i I — 



DI01 

Di02 

Di03 

DI04 

DI05 

Di06 

m07 

DI08 

T/R1 

DAV 

EOl 

ATN 

SRQ 

IFC 

NDAC 

NRFD 

T/R2 

REN 



D1 

D2 

D3 

D4 

D5 

D6 

D7 

AO 82 

RD 

WR 

RESET tt 

CS 

TCI 

SPI 

OBFI 

IBFi 

SYNC 

SS 

Xit 

X2t 
EA 



SRQ 

REN 

IFC 

ATNO 

COUNT 

E0I2 

ATN I 



IFCL 

cic 

CLTH 
SYC 



* = GPIB BUS TRANSCEIVER 

t = SEE 8041 A DATA SHEET FOR ALTERNATE 

CRYSTAL CONFIGURATIONS 
tt = CAN CONNECT TO SYSTEM RESET SWITCH, 

SEE 8041A DATA SHEET 
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NDAC 
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T/R2 
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EOi 

E0i2 
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IFCL 

cic 

CLTH OPTA 

SYC OPTB 
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18 X 




NDAC 
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NRFD 
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^6 
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13 
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12 
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Figure 3. 8291, 8292, and 8293 System Configuration 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias O^CtoZCC 

Storage Temperature -65**C to +150**C 

Voitage on Any Pin Witli Respect 

to Ground 0.5V to +7V 

Power Dissipation 1 .5 Watt 



^COMMENT: Stresses above ttiose listed under "Abso- 
lute IVIaximum Ratings" may cause permanent damage 
to the device. This is a stress rating only and functional 
operation of the device at these or any other conditions 
above those indicated in the operational sections of this 
specification is not implied. Exposure to absolute 
maximum rating conditions for extended periods may 
affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 

Ta=OX to 70 X, Vss = OV, 8292: Vcc= ±5V± 10% 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 






-0.5 


0.8 


V 




V|L1 


Input Low Voltage (All Except Xi, Xg, RESET) 




V|L2 


Input Low Voltage (Xi, X2, RESET) 


-0.5 


0.6 


V 




V|H1 


Input High Voltage (All Except Xi, Xg, RESET) 


2.2 


Vcc 


V 




V,H2 


Input High Voltage (Xi, X2, RESET) 


3.8 


Vcc 


V 




V0L1 


Output Low Voltage (D0-D7) 




0.45 


V 


loL= 2.0 mA 


V0L2 


Output Low Voltage (All Other Outputs) 




0.45 


V 


loL= 1-6 mA 


VOHI 


Output High Voltage (Dq-D/) 


2.4 




V 


Ioh=-400mA 


V0H2 


Output High Voltage (All Other Outputs) 


2.4 




V 


Ioh=-50mA 


l|L 


Input Leakage Current (COUNT, IFCL, RD, WR, OS, Aq) 




±10 


hA 


Vss<V,N<Vcc 


loz 


Output Leakage Current (D0-D7, High Z State) 




±10 


mA 


Vss + 0.45 <V,N< Vcc 


Ilii 


Low Input Load Current (Pins 21-24, 27-38) 




0.5 


mA 


V,L=0.8V 


'lI2 


Low Input Load Current (RESET) 




0.2 


mA 


V|L=0.8V 


Ice 


Total Supply Current 




125 


mA 


Typical = 65 mA 



A,C. CHARACTERISTICS 

Ta=OX to 70^0, Vss=OV, 8292: Vcc= +5V± 10% 
1. DBBREAD 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAR 


CS, Ao Setup to RDI 







ns 




tRA 


CS, Ao Hold After RDt 







ns 




tRR 


RD Pulse Width 


250 




ns 




tAD 


CS, Ao to Data Out Delay 




225 


ns 


Cl=150pF 


^RD 


RDI to Data Out Delay 




225 


ns 


Cl=150pF 


toF 


RDt to Data Float Delay 




100 


ns 




tcY 


Cycle Time 


2.5 


15 


MS 




2. DBB WRITE 


Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Uw 


CS, Ao Setup to WRI 







ns 




twA 


CS, Ao Hold After WRt 







ns 




tww 


WR Pulse Width 


250 




ns 




tow 


Data Setup to WRt 


150 




ns 




two 


Data Hold After WRI 







ns 





7-26 



8292 



3. COMMAND TIMINGS'^-'' 



Code 


Name 


Execution 
Time 


lint 


TCl'^J 


SRI 


ATNO 


cic 


TFC 


REN 


EOl 


DAV 


Comments 


E1 


WTOUT 


63 


24 




















E2 


WEVC 


63 


24 




















E3 


REVC 


71 


24 


51 


















E4 


RERF 


67 


24 


47 


















E5 


RINM 


69 


24 


49 


















E6 


RCST 


97 


24 


77 


















E7 


RBST 


92 


24 


72 


















E8 


























E9 


RTOUT 


69 


24 


49 


















EA 


RERM 


69 


24 


49 


















FO 


SPCNI 


53 


24 


















Count Stops After 39 


F1 


GIOL 


88 


24 


70 




t61 


t61 












F2 


RST 


94 


24 




152 














Not System Controller 


F2 


RST 


214 


24 


192 


152 


1179 


1174 


i101 








System Controller 


F3 


RSTI 


61 


24 




















F4 


GSEC 


125 


24 


107 




t98 














F5 


EXPP 


75 


24 












i53 
t59 


155 
157 






F6 


GTSB 


118 


24 


100 




191 














F7 


SLOG 


73 


24 


55 








t46 










F8 


SREM 


91 


24 


73 








m 










F9 


ABORT 


155 


24 


133 




1120 


1115 


M2 










FA 


TCNTR 


108 


24 


86 




171 


468 












FC 


TCAS 


92 


24 


67 




155 














FD 


TCSY 


115 


24 


91 




180 














FE 


STCNI 


59 


24 


















Starts Count After 43 


PIN 


RESET 


29 


— 


i7 


i7 














Not System Controller 


X 


lACK 


116 


— 




173 
t98 














If Interrupt Pending 



Notes: 1, All times are multiples of toy from the 8041 A command Interrupt. 

2. TCI clears after 7 tcy on all commands. 

3. t indicates a level transition from low to high, i indicates a high to low transition. 



WAVEFORMS 

1. READ OPERATION - DATA BUS BUFFER REGISTER. 



CS OR Ao 

(SYSTEM'S 

ADDRESS BUS) 




(READ CONTROL) 



2. WRITE OPERATION - DATA BUS BUFFER REGISTER. 



OS OR Ao 

(SYSTEM'S 

ADDRESS BUS) 




WR 
(WRITE CONTROL) 



DATA 
MAY CHANGE 
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APPENDIX 

The following tables and state diagrams were taken 
from the IEEE Standard Digital Interface for Program- 



mable Instrumentation, IEEE Std. 488-1978. This docu- 
ment is the official standard for the GPIB bus and can be 
purchased from IEEE, 345 East 47th St., New Yorl<, NY 
10017. 



C MNEMONICS 



Messages 


Interface States 


pon 


= power on 


CIDS 


= controller idle state 


rsc 


= request system control 


CADS 


= controller addressed state 


rpp 


= request parallel poll 


CTRS 


= controller transfer state 


gts 


= go to standby 


CACS 


= controller active state 


tea 


= take control asynchronously 


CPWS 


= controller parallel poll wait state 


tcs 


= take control synchronously 


CPPS 


= controller parallel poll state 


sic 
sre 


= send interface clear 
= send remote enable 


CSBS 
CSHS 


= controller standby state 
= controller standby hold state 


IFC 


= interface clear 


CAWS 


= controller active wait state 


ATN 


= attention 


CSWS 


= controller synchronous wait state 


TCT 


= take control 


CSRS 


= controller service requested state 






CSNS 


= controller service not requested state 






SNAS 


= system control not active state 






SACS 


= system control active state 






SRIS 


= system control remote enable idle state 






SRNS 


= system control remote enable not active state 






SRAS 


= system control remote enable active state 






SIIS 


= system control interface clear idle state 






SINS 


= system control interface clear not active state 






SIAS 


= system control interface clear active state 




(ACDS) 


= accept data state (AH function) 




(ANR$) 


= acceptor not ready state (AH function) 






(SDYS) 


= source delay state (SH function) 






(SIRS) 


= source transfer state (SH function) 






(TADS) 


= talker addressed state (T function) 




TCT A (ACDS) 

A 

[ (fADS) l 

gts A (IfRf)A(SDYUt^ 




tcs A (ANRS) 




€iC rV~Z 39 



* Tio>1.5/i8ec 

t THE MICROPROCESSOR MUST WAIT FOR THE BO 
INTERRUPT BEFORE WRITING THE QTS B OR GSEC 
COMMANDS TO ENSURE THAT (STRSaSISYS) 
IS TRUE. 




Figure A.1. State Diagram 
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REMOTE MESSAGE CODING 










C 

L 
A 
S 
S 




Bus Signal Line(s) and Coding That 
Asserts the True Value of the Message 


Mnemonic 


Message Name 


T 
Y 
P 

E 


D 

1 


8 


7 


6 


5 


4 


3 


2 


D 

1 



1 


NN 
DRD 
AFA 
VDC 


A 

T 
N 


E 


1 


S 1 R 
R F E 
Q C N 


ACQ 


Addressed Command Group 


M 


AC 


Y 





T 





~X 


Y 


X 


T 


XXX 


1 


X 


XXX 


ATN 


Attention 




U 


UC 


X 


X 


X 


X 


X 


X 


X 


X 


XXX 


1 


X 


XXX 


DAB 


Data Byte 


(Notes 1, 9) 


M 


DD 


D 
8 


D 

7 


D 
6 


D 
5 


D 

4 


D 
3 


D 
2 


D 
1 


XXX 





X 


XXX 


DAC 


Data Accepted 




U 


HS 


X 


X 


X 


X 


X 


X 


X 


X 


XXO 


X 


X 


XXX 


DAV 


Data Valid 




U 


HS 


X 


X 


X 


X 


X 


X 


X 


X 


1XX 


X 


X 


XXX 


DCL 


Device Clear 




M 


UC 


Y 








1 





1 








XXX 


1 


X 


XXX 


END 


End 




U 


ST 


X 


X 


X 


X 


X 


X 


X 


X 


XXX 





1 


XXX 


EOS 


End of String 


(Notes 2, 9) 


M 


DD 


E 
8 


E 
7 


E 
6 


E 
5 


E 

4 


E 
3 


E 
2 


E 
1 


XXX 





X 


XXX 


GET 


Group Execute Trigger 




M 


AC 


Y 











1 











XXX 


1 


X 


XXX 


GTL 


Go to Local 




M 


AC 


Y 




















1 


XXX 


1 


X 


XXX 


IDY 


Identify 




U 


UC 


X 


X 


X 


X 


X 


X 


X 


X 


XXX 


X 


1 


XXX 


IFC 


Interface Clear 




U 


UC 


X 


X 


X 


X 


X 


X 


X 


X 


XXX 


X 


X 


X 1 X 


LAG 


Listen Address Group 




M 


AD 


Y 





1 


X 


X 


X 


X 


X 


XXX 


1 


X 


XXX 


LLO 


Local Lock Out 




M 


UC 


Y 








1 











1 


XXX 


1 


X 


XXX 


MLA 


My Listen Address 


(Note 3) 


M 


AD 


Y 





1 


L 
5 


L 
4 


L 
3 


L 
2 


L 
1 


XXX 


1 


X 


XXX 


MTA 


My Talk Address 


(Note 4) 


M 


AD 


Y 


1 





T 
5 


T 
4 


T 
3 


T 
2 


T 
1 


XXX 


1 


X 


XXX 


MSA 


My Secondary Address 


(Note 5) 


M 


SE 


Y 


1 


1 


S 
5 


S 

4 


S 

3 


S 
2 


S 

1 


XXX 


1 


X 


XXX 


NUL 


Null Byte 




M 


DD 


























XXX 


X 


X 


XXX 


OSA 


Other Secondary Address 




M 


SE 










(OSA = 


SCG A MSA) 






OTA 


Other Talk Address 




M 


AD 










(OTA = 


TAG A MTA) 






PCG 


Primary Command Group 




M 


~ 






(PCG 


= ; 


^CG\ 


^ UCG V LAG V TAG) 


PPG 


Parallel Poll Configure 




M 


AC 


Y 














1 





1 


XXX 




X 


XXX 


PPE 


Parallel Poll Enable 


(Note 6) 


M 


SE 


Y 


1 


1 





S 


P 
3 
D 
3 
X 


P 
2 


P 

"1 


XXX 




X 


XXX 


PPD 


Parallel Poll Disable 


(Note 7) 


M 


SE 


Y 


1 


1 


1 


D 
4 
X 


D 
2 
X 


D 

1 

1 


XXX 




X 


XXX 


PPR1 


Parallel Poll Response 1 ^ 




U 


ST 


X 


X 


X 


X 


XXX 






XXX 


PPR2 


Parallel Poll Response 2 




U 


ST 


X 


X 


X 


X 


X 


X 


1 


X 


XXX 






XXX 


PPR3 


Parallel Poll Response 3 




U 


ST 


X 


X 


X 


X 


X 


1 


X 


X 


XXX 






XXX 


PPR4 
PPR5 


Parallel Poll Response 4 
Parallel Poll Response 5 


(Note 10) 


U 
U 


ST 
ST 


X 
X 


X 
X 


X 
X 


X 

1 


1 

X 


X 
X 


X 
X 


X 
X 


XXX 
XXX 






XXX 
XXX 


PPR6 


Parallel Poll Response 6 




U 


ST 


X 


X 


1 


X 


X 


X 


X 


X 


XXX 






XXX 


PPR7 


Parallel Poll Response 7 




U 


ST 


X 


1 


X 


X 


X 


X 


X 


X 


XXX 






XXX 


PPR8 


Parallel Poll Response 8^ 




U 


ST 


1 


X 


X 


X 


X 


X 


X 


X 


XXX 






XXX 


PPU 


Parallel Poll Unconflgure 




M 


UC 


Y 








1 





1 





1 


XXX 




X 


XXX 


REN 


Remote Enable 




U 


UC 


X 


X 


X 


X 


X 


X 


X 


X 


XXX 


X 


X 


X X 1 


RFD 


Ready for Data 




U 


HS 


X 


X 


X 


X 


X 


X 


X 


X 


xox 


X 


X 


XXX 


RQS 


Request Service 


(Note 9) 


U 


ST 


X 


1 


X 


X 


X 


X 


X 


X 


XXX 





X 


XXX 


SCG 


Secondary Command Groi 


JP 


M 


SE 


Y 


1 


1 


X 


X 


X 


X 


X 


XXX 


1 


X 


XXX 


SDC 


Selected Device Clear 




M 


AC 


Y 














1 








XXX 


1 


X 


XXX 


SPD 


Serial Poll Disable 




M 


UC 


Y 








1 


1 








1 


XXX 


1 


X 


XXX 


SPE 


Serial Poll Enable 




M 


UC 


Y 








1 


1 











XXX 


1 


X 


XXX 


SRQ 


Service Request 




U 


ST 


X 


X 


X 


X 


X 


X 


X 


X 


XXX 


X 


X 


1 X X 


STB 


Status Byte 


(Notes 8, 9) 


M 


ST 


S 
8 


X 


s 

6 


s 

5 


s 

4 


s 

3 


S 
2 


s 

1 


XXX 





X 


XXX 


TCT 


Take Control 




M 


AC 


Y 











1 








1 


XXX 


1 


X 


XXX 


TAG 


Talk Address Group 




M 


AD 


Y 


1 





X 


X 


X 


X 


X 


XXX 


1 


X 


XXX 


UCG 


Universal Command Group 


) 


M 


UC 


Y 








1 


X 


X 


X 


X 


XXX 


1 


X 


XXX 


UNL 


Unllsten 




M 


AD 


Y 





1 


1 


1 


1 


1 


1 


XXX 


1 


X 


XXX 


UNT 


Untaik 


(Note 11) 


M 


AD 


Y 


1 





1 


1 


1 


1 


1 


XXX 


1 


X 


XXX 



The 1/0 coding on ATN when sent concurrent with multiline messages has been added to this revision for interpre- 
tive convenience. 
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NOTES: 

1. D1-D8 specify the device dependent data bits. 

2. E1-E8 specify tlie device dependent code used to indicate tlie EOS message. 

3. L1-L6 specify the device dependent bits of the device's iisten address. 

4. T1-T5 specify the device dependent bits of the device's taik address. 

5. S1-S5 specify the device dependent bits of the device's secondary address. 

6. S specifies the sense of the PPR. 



Responses S0ist 
P1-P3 specify the PPR message to be sent when a parailel poii is executed. 
PS P2 P1 PPRiVlessage 
PPR1 



1 PPR8 



7. D1-D4 specify don't-care bits that shaii not be decoded by the receiving device. It is recommended that all zeroes 
be sent. 

8. S1-S6, S8 specify the device dependent status. (Di07 is used for the RQS message.) 

9. The source of the message on the ATN line is always the function, whereas the messages on the DIO and EOl 
lines are enabled by the T function. 

10. The source of the messages on the ATN and EOl lines is always the function, whereas the source of the 
messages on the DIO lines is always the PP function. 

11. This code is provided for system use, see 6.3. 
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8294 
DATA ENCRYPTION UNIT 



■ Certified by National Bureau of 
Standards 

■ 80 Byte/Sec Data Conversion Rate 

■ 64-Bit Data Encryption Using 56-Bit 
Key 

■ DIVIA interface 

■ 3 interrupt Outputs to Aid in Loading 
and Unloading Data 



■ 7-Bit User Output Port 

■ Single 5V ± 10% Power Supply 

■ Peripheral to MCS-Se^^, MCS-BS^^, 
MCS-aO^M and MCS-48tm Processors 

■ Implements Federal Information 
Processing Data Encryption Standard 

■ Encrypt and Decrypt Modes Available 



DESCRIPTION 

The Intel® 8294 Data Encryption Unit (DEU) Is a microprocessor peripheral device designed to encrypt and decrypt 
64-blt blocks of data using the algorithm specified in the Federal Information Processing Data Encryption Standard. 
The DEU operates on 64-bit text words using a 56-bit user-specified key to produce 64-bit cipher words. The operation 
Is reversible: If the cipher word Is operated upon, the original text word Is produced. The algorithm itself is perma- 
nently contained in the 8294; however, the 56-blt key Is user-defined and may be changed at any time. 

The 56-blt key and 64-bit message data are transferred to and from the 8294 in 8-bit bytes by way of the system data 
bus. A DMA interface and three interrupt outputs are available to minimize software overhead associated with data 
transfer. Also, by using the DMA Interface two or more DEUs may be operated in parallel to achieve effective system 
conversion rates which are virtually any multiple of 80 bytes/second. The 8294 also has a 7-blt TTL compatible output 
port for user-specified functions. 

Because the 8294 implements the NBS encryption algorithm it can be used in a variety of Electronic Funds Transfer 
applications as well as other electronic banking and data handling applications where data must be encrypted. 



PIN 
CONFIGURATION 



BLOCK DIAGRAM 



NCC 1 
XI C 2 

X2C 3 

RESET C 4 
NCC 5 
CSC 6 
GNDC 7 
RDC 8 
_AOC 9 
WRC 10 
SYNCC 11 
DOC 12 
D1 C 13 
D2C 14 
D3C 15 
D4|: 16 
D5C 17 
D6C 18 
D7C 19 
GNDC 20 



30 



3VCC 

IpNC 

3DACK 
7f]DRQ 
3SRQ 
BpOAV 
34 DNC 
33 3P6 
32 3P5 
31 DP4 



[P3 



29 DP2 
28 3 PI 
27 DPO 
26 3Vdd 
25pNC 

DCCMP 
23bNC 
22 DNC 
21 DNC 



DATA 
BUS 



(^ 



RD- 
WR- 

•cs- 

Ao- 

SRQ<»^ 

OAV* 

CCMP-^ 



RESET - 
SYNC- 



POWER - 
GND- 



DATA 

BUS 

BUFFER 

REGISTERS 



CONTROL 

AND 

INTERRUPT 

LOGIC 



INTERNAL 
BUS 



^- 



KEY 
BUFFER 
STORAGE 



ALGORITHM 
TABLE 



7-BIT A N 



DMA 
-y LOGIC 
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n# 


Pin Name 


1 


NC 


2 


X1 


3 


X2 


4 


RESET 


5 


NC 


6 


CS 


7 


GND 


8 


RD 



I/O 



Pin Description 



Pin # Pin Name i/0 



Pin Description 



10 



11 



WR 



SYNC 



12 


Do 


13 


Di 


14 


Dp 


15 


D3 


16 


D4 


17 


D5 


18 


Dfi 


19 


D7 


20 


GND 



— No connection. 

I Inputs for crystal, L-C or exter- 
nal timing signal to determine 
internal oscillator frequency. 

I A low signal to this pin resets 
the 8294. 

— No connection or tied high. 

I A low signal to this pin enables 
reading and writing to the 8294. 

— This pin must be tied to ground. 

I An active low read strobe at 
this pin enables the CPU to 
read data and status from the 
internal DEU registers. 

I Address input used by the CPU 
to select DEU registers during 
read and write operations. 

I An active low write strobe at 
this pin enables the CPU to 
send data and commands to 
the DEU. 

High frequency (Clock-;- 15) 
output. Can be used as a strobe 
for external circuitry. 

I/O Three-state, bi-directional data 
bus lines used to transfer data 
between the CPU and the 8294. 



This pin must be tied to ground. 



40 Vcc — +5 volt power input: -i-5V 

±10%. 

39 NC — No connection. 

38 DACK I DMA acknowledge. Input 

signal from the 8257 DMA Con- 
troller acknowledging that the 
requested DMA cycle has been 
granted. 

37 DRQ DMA request. Output signal to 

the 8257 DMA Controller 
requesting a DMA cycle. 

38 SRQ O Service Request. Interruot to 

the CPU indicating that the 
8294 is awaiting data or com- 
mands at the input buffer. 
SRQ=1 Implies IBF = 0. 

35 OAV Output Available. Interrupt to 

the CPU indicating that the 
8294 has data or status avail- 
able in its output buffer. 
0AV=1 implies 0BF=1. 

— No connection. 

User output port lines. Output 
lines available to the user via a 
CPU command which can as- 
sert selected port lines. These 
lines have nothing to do with 
the encryption function. At 
power-on, each line is in a 1 
state. 

26 Vdd — -I- 5V power input. ( + 5V ±10%) 

Low power standby pin. 



34 


NC 


33 


P6 


32 


P5 


31 


P4 


30 


P3 


29 


P2 


28 


PI 


27 


PO 



25 


NC 


— 


No connection. 


24 


CCMP 





Conversion Complete. Interrupt 
to the CPU indicating that the 
encryption/decryption of an 
8-byte block is complete. 


23 


NC 


— 


No connection. 


22 


NC 


— 


No connection. 


21 


NC 


— 


No connection. 
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BASIC FUNCTIONAL DESCRIPTION 
OPERATION 

The data conversion sequence is as follows: 

1. A Set Mode command is given, enabling the desired 
interrupt outputs. 

2. An Enter New Key command is issued, followed by 8 
data inputs which are retained by the DEU for encryp- 
tion/decryption. Each byte must have odd parity. 

3. An Encrypt Data or Decrypt Data command sets the 
DEU in the desired mode. 

After this, data conversions are made by writing 8 data 
bytes and then reading back 8 converted data bytes. Any 
of the above commands may be issued between data 
conversions to change the basic operation of the DEU; 
e.g., a Decrypt Data command could be issued to 
change the DEU from encrypt mode to decrypt mode 
without changing either the key or the interrupt outputs 
enabled. 

INTERNAL DEU REGISTERS 

Four internal registers are addressable by the master 
processor: 2 for input, and 2 for output. The following 
table describes how these registers are accessed. 

RD WR CS Aq Register 



1 











Data input buffer 





1 








Data output buffer 


1 








1 


Command input buffer 





1 





1 


Status output buffer 


X 


X 


1 


X 


Don't care 



The functions of each of these registers are described 
below. 

Data Input Buffer — Data written to this register is inter- 
preted in one of three ways, depending on the preceding 
command sequence. 

1 . Part of a key. 

2. Data to be encrypted or decrypted. 

3. A DMA block count. 



IBF Input Buffer Full; A write to the Data Input Buffer 
or to the Command Input Buffer sets IBF = 1 . The 
DEU resets this flag when it has accepted the 
input byte. Nothing should be written when 
IBF=1. 

DEC Decrypt; indicates whether the DEU is in an en- 
crypt or a decrypt mode. DEC = 1 implies the 
decrypt mode. DEC = implies the encrypt 
mode. 

CF Completion Flag; This flag may be used to indi- 
cate any or all of three events in the data transfer 
protocol. 

1. it may be used in lieu of a counter in the 
processor routine to flag the end of an 8- 
byte transfer. 

2. It must be used to indicate the validity of 
the KPE flag. 

3. It may be used in lieu of the CCMP interrupt 
to indicate the completion of a DMA oper- 
ation. 

KPE Key Parity Error; After a new key has been 
entered, the DEU uses this flag in conjunction 
with the CF flag to indicate correct or incorrect 
parity. 

COMMAND SUMMARY 
1 — Enter New Key 

OP CODE: |0 I 1 I I I 0| I 0| o| 

MSB LSB 

This command is followed by 8 data byte inputs which 
are retained in the key buffer (RAM) to be used in 
encrypting and decrypting data. These data bytes must 
have odd parity represented by the LSB. 



2 — Encrypt Data 

OP CODE: |o|o|l|l|o|o|o|o] 



MSB LSB 

This command puts the 8294 into the encrypt mode. 



Data Output Buffer — Data read from this register is the 
output of the encryption/decryption operation. 

Command Input Buffer — Commands to the DEU are 
written into this register. (See command summary 
below.) 

Status Output Buffer — DEU status is available in this 
register at all times. It is used by the processor for poll- 
driven command and data transfer operations. 

STATUS BIT: 
FUNCTION: 

OBF Output Buffer Full; DBF = 1 indicates that output 
from the encryption/decryption function is 
available in the Data Output Buffer. It is reset 
when the data is read. 



7 


6 


5 


4 


3 


2 


1 





X 


X 


X 


KPE 


CF 


DEC 


IBF 


OBF 









1 


















3 — Decrypt Data 

OP CODE: 

MSB LSB 

This command puts the 8294 into the decrypt mode. 

4 — Set Mode 

OP CODE: |0 I 0| I 0| A I B I C 1^ 



MSB 



LSB 



where: 

A is the OAV (Output Available) interrupt enable 
B is the SRQ (Service Request) interrupt enable 
C is the DMA (Direct Memory Access) transfer enable 
D is the CCMP (Conversion Complete) interrupt enable 
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This command determines which interrupt outputs will 
be enabled. A "1" In bits A, B, or D will enable the OAV, 
SRQ, or CCMP Interrupts respectively. A "1" in bit C will 
allow DMA transfers. When bit C Is set the OAV and 
SRQ interrupts should also be enabled (bits A,B = 1). 
Following the command In which bit C, the DIVIA bit, is 
set, the 8294 will expect one data byte to specify the 
number of 8-byte bJocks to be converted using DMA. 

5 — Write to Output Port 

OP CODE: |1 I Pfi I P.; I Pa I P.-^ I P9 I Pi I Pn I 



MSB 



LSB 



This command causes the 7 least significant bits of the 
command byte to be latched as output data on the 8294 
output port. The initial output data Is 1111111. Use of 
this port is Independent of the encryption/decryption 
function. 



After the Enter New Key command is Issued, 8 data 
bytes representing the new key are written to the data 
input buffer (most significant byte first). After the eighth 
byte Is accepted by the DEU, CF goes true (CF= 1). The 
OF bit goes false again when KPE Is valid. The CPU can 
then check the KPE flag. If KPE = 1, a parity error has 
been detected and the DEU has not accepted the key. 
Each byte Is checked for odd parity, where the parity bit 
Is the LSB of each byte. 

Since the CF bit Is used in this protocol to indicate the 
validity of the KPE flag, it may not be used to flag the 
end of the 8 byte key entry. CF = 1 only as long as KPE Is 
inva<td. Therefore, the CPU might not detect that CF = 1 
and the key entry is complete before KPE becomes 
valid. Thus, a counter should be used, as in Figure 2, to 
flag the end of the new key entry. Then, CF is used to 
indicate a valid KPE flag. 



PROCESSOR/DEU INTERFACE PROTOCOL 

ENTERING A NEW KEY 

The timing sequence for entering a new key is shown in 
Figure 1. A flowchart showing the CPU software to 
accommodate this sequence Is given In Figure 2. 



!~LrLrL__j""L 
=_rL_ri_rL____n 



=3 



X 



Ao.n 



"Lr"iJ- 



""ij" 



____rL 



w 



i I [key I [key ~1 [key 

LJ LJ DATA LJ DATA LJ DATi 



NEW ^ 

KEY 

COMMAND 




COMMAND REGISTER— 40H 



Lno( ^ IBF^O? ) 



DATA REGISTER 1 BYTE OF KEY 



L ^ IBF = 0? ) 



-JiQ ( 1=8? ) 

I — i^f^s 

1 ^ CF = 0? ) 
\ YES 

-MQ { kpe = o? ) 



Figure 1. Entering a New Key 



Figure 2. Flowchart for Entering a New Key 
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ENCRYPTING OR DECRYPTING DATA 

Figure 3 shows the timing sequence for encrypting or 
decrypting data. The CPU writes 8 data bytes to the 
DEU's data input buffer for encryption/decryption. CF 
then goes true (CFs1) to indicate that the DEL) has 
accepted the 8-byte bloclc. Thus, the CPU may test for 
iBF:aO and CF=1 to terminate the input mode, or it 
may use a software counter. When the encryption/- 
decryption is compiete, the CCMP and OAV interrupts 
are asserted and the OBF flag is set true (OBF = 1). OAV 
and OBF are set false again after each of the converted 
data bytes is read bacic by the CPU. The CCMP interrupt 
is set false, and remains false, after the first read. After 
8 bytes have been read back by the CPU, CF goes false 
(CF = 0). Thus, the CPU may test for CF = to terminate 
the read mode. Also, the CCMP interrupt may be used to 
initiate a service routine which performs the next series 
of 8 data reads and 8 data writes. 



USING SOFTWARE COUNTER 



3"LrL_J~L 

^Ji__n_ r 



OAV 
(IF ENABLED) 



a_rL 



a 



ij~i;""Lr 



*ir"U""u 



8 DATA WRITES 100 ms - MAXIMUM 



Figure 3. Encrypting/Decrypting Data 



Figure 4 offers two flowcharts outlining the alternative 
means of implementing the data conversion protocol. 
Either the CF flag or a software counter may be used to 
end the read and write modes. 



(start] 



*") YES 



DATA REGISTER-*— 1 DATA BYTE 

— _ 



LNg ( ,BF.O? ) 



- ^ 1.8? ) 

■^JYES^ 



NO 



f OBFxrl? J 

Iyes 



READ 1 CODED DATA BYTE 



I 



<3HD 




( IBF = 0? J 



DATA REGISTER-^ 1 DATA BYTE 



I YES 



NO, 



/ CF = 1? J 

4yes 



(Tr^Pp5_>Q 



- ^ 0BF = 1? ) 

^YES 



READ 1 CODED DATA BYTE 



SR0=1 Implies IBF = 0, 0AV=1 implies OBF= 1. This 
allows Interrupt routines to do data transfers without 
checking status first. However, the OAV service routine 
must detect and flag the end of a data conversion. 



Figure 4. Data Conversion Flowcharts 
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USING DMA 

The timing sequence for data conversions using DMA is 
shown in Figure 5. This sequence can be better 
understood when considered in conjunction with the 
hardware DIVIA interface in Figure 6. Note that the use of 
the DIVIA feature requires 3 external AND gates and 2 
DMA channels (one for input, one for output). Since the 
DEU has only one DMA request pin, the SRQ and OAV 
outputs are used in conjunction with two of the AND 
gates to create separate DMA request outputs for the 2 
DMA chan nels. T he third AND gate combines the two 
active-low DACK inputs. 



CCMP 
(IF ENABLED) 



r 



=zn. 



'"«nnnr"i 



J~L_J 



rLr""LrL___rL 



"irLr""LJ~ 

Lf LJ~ 



-"innr"!] 



DMA BLOCK 8 DMA READS 

MODE COUNT (n) 



8 DMA WRITES 



To initiate a DMA transfer, the CPU must first initialize 
the two DMA channels as shown in the flowchart In 
Figure 7. It must then issue a Set Mode command to the 
DEU enabling the OAV, SRQ, and DMA outputs. The 
CCMP interrupt may be enabled or disabled, depending 
on whether that output is desired. Following the Set 
Mode command, there must be a data byte giving the 
number of 8-byte blocks of data (n<256) to be converted. 
The DEU then generates the required number of DMA 
requests to the 2 DMA channels with no further CPU 
Intervention. When the requested number of blocks 
has been converted, the DEU will set CF and assert the 
CCMP interrupt (if enabled). CCMP then goes false 
again with the next write to the DEU (command or data). 
Upon completion of the conversion, the DMA mode is 
disabled and the DEU returns to the encrypt/decrypt 
mode. The enabled interrupt outputs, however, will 
remain enabled until another Set Mode command is 
issued. 



USING DMA 
BTAR11 



INITIALIZE DMA READ CHANNEL POINTER 



INITIALIZE DMA WRITE CHANNEL POINTER 



ENABLE DMA CHANNELS 



REPEATED n TIMES 



= 0? J 



Figure 5. DMA Sequence 



COMMAND REGISTER OEM OR OFH 




l-NO-( IBF = 0? ) 



DATA REGISTER -" NUMBER OF BLOCKS TO BE CODED 



LnO-( CF = 1? ) 



1 YES 
(END) 



Figure 7. DMA Flowchart 



Figure 6. DMA Interface 



SINGLE BYTE COMMANDS 

Figure 8 shows the timing and protocol for single byte 
commands. Note that any of the commands is effective 
as a pacify command in that they may be entered at any 
time, except during a DMA conversion. The DEU is thus 
set to a known state. However, if a command is issued 
out of sequence, an additional protocol is required 
(Figure 9). The CPU must wait until the command is 
accepted (IBF = 0). A data read must then be issued to 
clear anything the preceding command sequence may 
have left In the Data Output Buffer. 
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CPU/DEU INTERFACES 

Figures 10 through 13 Illustrate four interface configura- 
tions used In the CPU/DEU data transfers. In all cases 
SRQ wifl be true (if enabled) ar>d IBF will be false when 
the DEU Is ready to accept data or commands. 



R 



I START 1 



'9^ IbfIo? ^ 



COMMAND REGISTER COMMAND 







Figure 8. Single Byte Commands 



INTERFACE TO 8086, 8088, 

8080, 8085, 8048, OR — 
OTHER PROCESSOR 




Figure 10. Polling Interface 



MASTER 
PROCESSOR 
INTERFACE 




( START J 



-I IBF = 0? j 



COMMAND REGISTER-*— OOH 



-/ IBF = 0? J 



READ DATA REGISTER 




Figure 9. Pacify Protocol 



Figure 11. Single Interrupt Interface 




Figure 12. Dual Interrupt Interface 
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Ao-Ai5 D0-D7 




r 

< 15 pF I 
(INCLUDES XTAL, dp 
SOCKET, STRAY) I 



15-25 pF 
(INCLUDES 
SOCKET, -±r 
STRAY) 




DMARO IS FOR MEMORY TO DEU DATA TRANSFER 
DMAR1 IS FOR DEU TO MEMORY DATA TRANSFER 
USE OF CCMP IS OPTIONAL 



Figure 13. DMA Interface 



OSCILLATOR AND TIMING CIRCUITS 

The 8294's internal timing generation is controlled by a 
self-contained oscillator and timing circuit. A choice of 
crystal, L-C or external clock can be used to derive the 
basic oscillator frequency. 

The resident timing circuit consists of an oscillator, a 
state counter and a cycle counter as illustrated in Figure 
14. 



HDh 




6 MHz 
OSCILLATOR 



+3 

STATE 

COUNTER 



4-5 

CYCLE 

COUNTER 



INTERNAL TIMING 



SYNC 
-OUTPUT 
(2.5 jusec) 



Figure 14. Oscillator Configuration 



OSCILLATOR 

The on-board oscillator is a series resonant circuit with 
a frequency range of 1 to 6 MHz. Pins X1 and X2 are 
input and output (respectively) of a high gain amplifier 
stage. A crystal or inductor and capacitator connected 
between X1 and X2 provide the feedback and proper 
phase shift for oscillation. Recommended connections 
for crystal or L-C are shown in Figure 15. 



Figure 15. Recommended Crystal and L-C Connections 

A recommended range of inductance and capacitance 
combinations is given below: 

L= 120mH corresponds to 3 MHz 
L= 45jLiH corresponds to 6 MHz 
An external clock signal can also be used as a frequency 
reference to the 8294; however, the levels are not com- 
patible. The signal must be in the 1MHz-6MHz fre- 
quency range and must be connected to pins X1 and X2 
by buffers with a suitable pull-up resistor to guarantee 
that a logic "1" is above 3.8 volts. The recommended 
connection is shown in Figure 16. 
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STANDARD TTL OR 
OPEN COLLECTOR 



Figure 16. Recommended Connection for External Cloclt Signal 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0*'C to 70'C 

Storage Temperature -65X to + ISO^'C 

Voltage on Any Pin With 

Respect to Ground 0.5V to + 7V 

Power Dissipation 1.5 Watt 



^COMMENT 

Stresses above those listed under "Absolute Maximum Ratings" may 
cause permanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other conditions above 
those indicated in the operational sections of this specification is not 
implied. Exposure to absolute maximum rating conditions for extended 
periods may affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 

TA=0°Cto70°C, Vcc = Vdd=+5V±10%,Vss = 0V 



Symbol 


Parameter 


Limits 


Unit 


TasI Conditions 


Min. 


Typ. 


Max. 




V|L 


Input Low Voltage (All 
Except Xi, X2, RESET) 


-0.5 




0.8 


V 




V|L1 


Input Low Voltage (Xi, X2, 
RESET) 


-0.5 




0.6 


V 




V|H 


Input High Voltage (All 
Except Xi, X2, RESET) 


2.2 




Vcc 


V 




V|H1 


Input High Voltage (Xi, X2, 
RESrn 


3.8 




Vcc 


V 




Vol 


Output Low Voltage (D0-D7) 






0.45 


V 


loL= 2.0 mA 


V0L1 


Output Low Voltage (All 
Other Outputs) 






0.45 


V 


loL=1-6mA 


Vqh 


Output High Voltage (D0-D7) 


2.4 






V 


Ioh=-400mA 


V0H1 


Output High Voltage (All 
Other Outputs) 


2.4 






V 


loH=-50fiA 


l|L 


Input Leakage Current 
(RD, WR, OS, Ao) 






±10 


mA 


Vss<V,N<Vcc 


Iqz 


Output Leakage Current 
(D0-D7, High Z State) 






±10 


mA 


Vss + 0.45 <V|N< Vcc 


Idd 


Vdd Supply Current 




5 


15 


mA 




Idd+Iqc 


Total Supply Current 




60 


125 


mA 




Ili 


Low Input Load Current 
(Pins 24, 27-38) 






0.5 


mA 


V,L=0.8V 


Ilii 


Low Input Load Current 
(RESET) 






0.2 


mA 


V,L=0.8V 
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A.C. CHARACTERISTICS 

TA=0*'Cto70X, Vcc = Vdd=+5V±10%, Vss=OV 


DBB READ 


Symbol 


Parameter 


MIn. 


Max. 


Unit 


Test Conditions 


tAR 


CS, Ao Setup to RD 1 







ns 




tRA 


C5, Ao Hold After RD t 







ns 




tRR 


RD Pulse Width 


250 




ns 




tAD 


CS, Ao to Data Out Delay 




225 


ns 


Cl=150pF 


tRD 


RD i to Data Out Delay 




225 


ns 


Cl=150pF 


tDF 


RD t to Data Float Delay 




100 


ns 




tcY 


Cycle Time 


2.5 


15 


MS 


6 MHz Crystal 


DBB WRITE 


Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAW 


CS, Ao Setup to WR I 







ns 




^WA 


C§, Ao Hold After WRt 







ns 




tww 


WR Pulse Width 


250 




ns 




^DW 


Data Setup to WR t 


150 




ns 




twD 


Data Hold to WRt 







ns 




DMA AND INTERRUPT TIMING 


Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Ucc 


DACK Setup to Control 







ns 




tCAC 


DACK Hold After Control 







ns 




UCD 


DACK to Data Valid 




225 


ns 




tCRQ 


Control LE. to DRQ I.E. 




200 


ns 




tci 


Control T.E. to Interrupt T.E. 




tcY+500 


ns 
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WAVEFORMS 

1. READ OPERATION - OUTPUT BUFFER REGISTER. 



CS OR Ao 



K 



^. 



./■ 



tAD- 



DATA BUS 
(OUTPUT) 



< 



> 



X 



(SYSTEM'S 
ADDRESS BUS) 



(READ CONTROL) 



2. WRITE OPERATION - INPUT BUFFER REGISTER. 



CS OR Ao 



X 



1 



DATA BUS 
(INPUT) 



DATA 
MAY CHANGE 



./' 



V- DATA VALID ►V 



DATA 
MAY CHANGE 



(SYSTEM'S 
ADDRESS BUS) 



(WRITE CONTROL) 



DMA AND INTERRUPT TIMING 





\ 


tACC— - 

\ 










tCAy^- 








\ 




/ 








\ 


/ 




















-. tCRC 


\ 

» 


\ 
















DATA BUS— - 


* 'AUU 








> 


^ VALID 


^C 
























\ 

^ Tci 


\ 
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8295 
DOT MATRIX PRINTER CONTROLLER 



Interfaces Dot Matrix Printers to 
MCS-48'"", i«ICS■80/85'^ IWCS-86™ 
Systems 

40 Character Buffer On Chip 

Serial or Parallel Communication with 
Host 

DMA Transfer Capability 

Programmable Character Density (10 or 
12 Chararcters/lnch) 



Programmable Print Intensity 



Single or Double Width Printing 



Programmable Multiple Line Feeds 



3 Tabulations 



■ 2 General Purpose Outputs 



The Intel® 8295 Dot Matrix Printer Controller provides an interface for microprocessors to the LRC 7040 Series dot 
matrix Impact printers. It may also be used as an Interface to other similar printers. 

The chip may be used In a serial or parallel communication mode with the host processor. In parallel mode, data 
transfers are based on polling, interrupts, or DMA. Furthermore, It provides Internal buffering of up to 40 characters 
and contains a 7x 7 matrix character generator accommodating 64 ASCII characters. 



PIN 
CONFIGURATION 



PFEEDC 1 

XTAUC 2 

XTAL2C 3 

WSETC 4 

NCC 5 

"CSC 6 

QNDC 7 

IdC 8 

VccC 9 

SYNCC 11 
DoC 12 
DiC 13 
D2C 14 

DaC 15 

D4C 16 
05 C 17 

DeC 18 

OjC 19 
QNDC 20 



DVcc 

J HOME 

JDACK/SIN 
3DRQ/CT5 

Dirq/Ser 

jmf 

DSTB 

:]^ 

D5T 

DVdd 

Dnc 

jQPt 



BLOCK DIAGRAM 



•c^ 



«> 



DRQ/CTS 

■REsIt 

IRQ/5ER 

SYNC - 
XTAL1 - 
XTAL2 - 





CONTROL 








►o 



CONTROL <(^ \ 



<^ 



<^ 



- STB 

► MOT 

► PFM 

- HOME 

- PFEED 



Lr 



^ 
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8295 



Name 



I/O Pin# 



Description 



Name 



i/0 Pin# 



Description 



PFEED 

XTAL1 
XTAL2 



RESET 



NC 
CS 

GND 
RD 



Vcc 
WR 



SYNC 



- 7 



Do 


I/O 12 


Di 


13 


D2 


14 


D3 


15 


D4 


16 


D5 


17 


De 


18 


D7 


19 


GND 


— 20 



I 1 Paper feed input switch. 

I 2 Inputs for a crystal to set internal 
3 oscillator frequency. For proper 
operation use 6 MHz crystal. 

I 4 Reset input, active low. After 
reset the 8295 will be set for 12 
characters/inch single width 
printing, solenoid strobe at 320 
msec. 

— 5 No connection or tied high. 

I 6 Chip select input used to enable 
the RD and WR inputs except dur- 
ing DMA. 

This pin must be tied to ground. 

8 Read input which enables the 
master CPU to read data and 
status. In the serial mode this pin 
must be tied to Vqc- 

9 +5 volt power input: + 5V± 10%. 

10 Write input which enables the 
master CPU to write data and 
commands to the 8295. In the 
serial mode this pin must be tied 
to Vss- 

11 2.5 ^JlS clock output. Can be used 
as a strobe for external circuitry. 

Three-state bidirectional data bus 
buffer lines used to interface the 
8295 to the host processor in the 
parallel mode. In the serial mode 
D0-D2 sets up the baud rate. 



This pin must be tied to ground. 
— 40 -f-5 volt power input: -I- 5V± 10%. 



DACK/SIN I 38 



DRQ/CTS O 37 



HOME I 39 Home input switch, used by the 

8295 to detect that the print head 
is in the home position. 

In the parallel mode used as DMA 
acknowledgement; in the serial 
mode, used as input for data. 

In the parallel mode used as DMA 
request output pin to indicate to 
the 8257 that a DMA transfer is re- 
quested; in the serial mode used 
as clear-to-send signal. 

IRQ/SER O 36 In parallel mode it is an interrupt 
request input to the master CPU; 
in serial mode it should be 
strapped to Vss- 



MOT 





35 


Main motor drive, active low. 


STB 





34 


Solenoid strobe output. Used to 
determine duration of solenoids 
activation. 


S'j 





33 


Solenoid drive outputs; active 


Se 




32 


low. 


s^ 




31 




S4 




30 




s; 




29 




Sp 




28 




ST 




27 




Vdd 


— 


26 


-I-5V power input (h-5V±10%). 
Low power standby pin. 


NC 


— 


25 


No connection. 


GP1 





24 


General purpose output pins. 


GP2 





23 




TOF 


1 


22 


Top of form input, used to sense 
top of form signal for type T 
printer. 


PFM 





21 


Paper feed motor drive, active 
low. 
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FUNCTIONAL DESCRIPTION 



The 8295 interfaces microcomputers to the LRC 7040 
Series dot matrix impact printers, and to other similar 
printers. It provides internal buffering of up to 40 char- 
acters. Printing begins automatically when the buffer is 
full or when a carriage return character is received. It 
provides a modified 7x7 matrix character generator. The 
character set includes 64 ASCII characters. 



Communication between the 8295 and the host proc- 
essor can be implemented in either a serial or parallel 
mode. The parallel mode allows for character transfers 
into the buffer via DMA cycles. The serial mode features 
selectable data rates from 110 to 4800 baud. 

The 8295 also offers two general purpose output pins 
which can be set or cleared by the host processor. They 
can be used with various printers to implement such 
functions as ribbon color selection, enabling form 
release solenoid, and reverse document feed. 



COMMAND SUMMARY 

Hex Code Description 

00 Set GP1. This command brings the GP1 pin 
to a logic high state. After power on it is 
automatically set high. 

01 Set GP2. Same as the above but for GP2. 

02 Clear GP1. Sets GP1 pin to logic low state, 
inverse of command 00. 

03 Clear GP2. Same as above but for GP2. In- 
verse command 01. 

04 Software Reset. This is a pacify command. 
This command is not effective immediately 
after commands requiring a parameter, as 
the Reset command will be interpreted as a 
parameter. 

05 Print 10 characters/in. density. 

06 Print 12 characters/in. density. 

07 Print double width characters. This com- 
mand prints characters at twice the normal 
width, that is, at either 17 or 20 characters 
per line. 

08 Enable DMA mode; must be followed by 
two bytes specifying the number of data 
characters to be fetched. Least significant 
byte accepted first. 



Description 



l-lex Code 

09 Tab character. 

OA Line feed. 

OB Multiple Line Feed; must be followed by a 

byte specifying the number of line feeds. 

OC Top of Form. Enables the line feed output 

until the Top of Form input is activated. 

OD Carriage Return. Signifies end of a line and 

enables the printer to start printing. 

OE Set Tab #1, followed by tab position byte. 

OF Set Tab #2, followed by tab position byte. 

Should be greater than Tab #1. 

10 Set Tab #3, followed by tab position byte. 
Should be greater than Tab #2. 

11 Print Head Home on Right. On some 
printers the print head home position is on 
the right. This command would enable nor- 
mal left to right printing with such printers. 

12 Set Strobe Width; must be followed by 
strobe width selection byte. This command 
adjusts the duration of the strobe activa- 
tion. 



PROGRAMMABLE PRINTING OPTIONS 

CHARACTER DENSITY 

The character density is programmable at 10 or 12 char- 
acters/inch (32 or 40 characters/line). The 8295 is auto- 
matically set to 12 characters/inch at power-up. Invoking 
the Print Double-Width command halves the character 
density (5 or 6 characters/inch). The 10 char/In or 12 
char/in command must be re-issued to cancel the 
Double-Width mode. Different character density modes 
may not be mixed within a single line of printing. 

PRINT INTENSITY 

The intensity of the printed characters is determined by 
the amount of time during which the solenoid is on. This 
on-time is programmable via the Set Strobe-Width com- 
mand. A byte following this command sets the solenoid 
on-time according to Table 1. Note that only the three 
least significant bits of this byte are important. 



D7-D3 


D2 


D1 


DO 


Solenoid On 
(microsec) 


X 











200 


X 








1 


240 


X 





1 





280 


X 





1 


1 


320 


X 


1 








360 


X 


1 





1 


400 


X 


1 


1 





440 


X 


1 


1 


1 


480 



Table 1. 



TABULATIONS 



Up to three tabulation positions may be specified with 
the 8295. The column position of each tabulation is 
selected by issuing the Set Tab commands, each fol- 
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lowed by a byte specifying the column. The tab posi- 
tions will then remain valid until new Set Tab commands 
are issued. 

Sending a tab character (09H) will automatically fill the 
character buffer with blanks up to the next tab position. 
The character sent immediately after the tab character 
vyill thus be stored and printed at that position. 

CPU TO 8295 INTERFACE 

Communication between the CPU and the 8295 may 
take place in either a serial or parallel mode. However, 
the selection of modes is inherent In the system hard- 
ware; it is not software programmable. Thus, the two 
modes cannot be mixed in a single 8295 application. 

PARALLEL INTERFACE 

Two internal registers on the 8295 are addressable by 
the CPU: one for input, one for output. The following 
table describes how these registers are accessed. 



the 8257 DMA controller without further CPU interven- 
tion. Figure 2 shows a block diagram of the 8295 in DMA 
mode. 



r 


BEGIN 


^ 










READ 8295 
STATUS 






^ 


TEST IBF 


s 


BUSY 



WRITE TO 8295 
A0»0 



8295 STATUS 
IBF = 1 



RD WR CS 



Register 



7 


6 


5 


4 


3 


2 


1 





X 


X 


PA 


DE 


X 


X 


IBF 


X 



1 Input Data Register 
1 Output Status Register 

Input Data Register— Data written to this register is 
interpreted in one of two ways, depending on how the 
data is coded. 

1. A command to be executed (OXH or 1XH). 

2. A character to be stored in the character buffer for 
printing (2XH, 3XH, 4XH, or 5XH). See the character 
set. Table 2. 

Output Status Register—8295 status is available in this 
register at all times. 



STATUS BIT: 
FUNCTION: 



PA— Parameter Required; PA=1 indicates that a com- 
mand requiring a parameter has been received. After the 
necessary parameters have been received by the 8295, 
the PA flag is cleared. 

DE— DMA Enabled; DE = 1 whenever the 8295 is in DMA 
mode. Upon completion of the required DMA transfers, 
the DE flag is cleared. 

IBF— Input Buffer Full; IBF= 1 whenever data Is written 
to the Input Data Register. No data should be written to 
the 8295 when IBF=1. 

A flow chart describing communication with the 8295 is 
shown in Figure 1. 

The interrupt request output (IRQ, Pin 36) is available on 
the 8295 for interrupt driven systems. This output is 
asserted true whenever the 8295 is ready to receive data. 

To improve bus efficiency and CPU overhead, data may 
be transferred from main memory to the 8295 via DMA 
cycles. Sending the Enable DMA command (08H) acti- 
vates the DMA channel of the 8295. This command must 
be followed by two bytes specifying the length of the 
data string to be transferred (least significant byte first). 
The 8295 will then assert the required DMA requests to 



Figure 1. Host to 8295 Protocol Flowchart 



^F=^ 
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DRQx 
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wR 

RESET 
8295 
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STB 
PFEED 
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Figure 2. Parallel System Interface 



Data transferred in the DMA mode may be either com- 
mands or characters or a mixture of both. The procedure 
Is as follows: 

1. Set up the 8257 DMA controller channel by sending a 
starting address and a block length. 

2. Set up the 8295 by issuing the "Enable DMA" com- 
mand (08H) followed by two bytes specifying the 
block length (least significant byte first). 

The DMA enabled flag (DE) will be true until the 
assigned data transfer is completed. Upon completion 
of the transfer, the flag is cleared and the interrupt re- 
quest (IRQ) signal is asserted. The 8295 then returns to 
the non-DMA mode of operation. 
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SERIAL INTERFACE 

The 8295 may be hardware programmed to operate in 
a s erial mode of communication. By connecting the 
IRQ/SER pin (pin 36) to iogic zero, the seriai mode is 
enabied immediately upon power-up. The serial Baud 
rate is also hardware programmable; by strapping pins 
14, 13^and 12 according to Table 2, the rate is selected. 
CS, RD, and WR must be strapped as shown In Figure 3. 



Pin 14 


Pin 13 


Pln12 


Baud Rate 











110 








1 


150 





1 





300 





1 


1 


600 


1 








1200 


1 





1 


2400 


1 


1 





4800 


1 


1 


1 


4800 



Table 2. 

The serlal data format is shown in Figu re 3 . The CPU 
should wait for a clear to send signal (CTS) from the 
8295 before sending data. 
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Figure 4. 8295 To Printer Solenoid Interface 



OSCILLATOR AND TIMING CIRCUITS 

The 8295's internal timing generation is controlled by a 
self-contained oscillator and timing circuit. A 6 MHz 
crystal is used to derive the basic oscillator frequency. 
The resident timing circuit consists of an oscillator, a 
state counter and a cycle counter as illustrated in Figure 
5. The recommended crystal connection is shown in 
Figure 6. 
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Figure 5. Oscillator Configuration 



Figure 3. Serial Interface to UART (8251A) 



8295 TO PRINTER INTERFACE 

The strobe output signal of the 8295 determines the 
duration of the solenoid outputs, which hold the data to 
the printer. These solenoid outputs cannot drive the 
printer solenoids directly. They should be buffered 
through solenoid drivers as shown in Figure 4. Recom- 
mended solenoid and motor driver circuits may be found 
in the printer manufacturer's interface guide. 



20 pF; 




Figure 6. Recommended Crystal Connection 
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8295 


CHARACTER SET 
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20 




space 




30 





40 


@ 


50 


P 


21 




! 




31 


1 


41 


A 


51 


Q 


22 




" 




32 


2 


42 


B 


52 


R 


23 




# 




33 


3 


43 





53 


S 


24 




$ 




34 


4 


44 


D 


54 


T 


25 




% 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0°O to70*O 

Storage Temperature -65° to + 150 ''C 

Voltage on Any Pin With 

Respect to Ground 0.5V to + 7V 

Power Dissipation 1 .5 Watt 



*COMMENT: Stresses above those listed under "Absolute Maximum 
Ratings" may cause permanent damage to the device. This is a stress 
rating only and functional operation of the device at these or any other 
conditions above those indicated in the operational sections of this 
specification is not implied. Exposure to absolute maximum rating con- 
ditions for extended periods may affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 

Ta= 0°C to 70°C, Vcc= Vdd= +5V± 10%, Vss= OV 



Symbol 


Parameter 


Limits 


Unit 


TaqI Conditloim 


Min. 


Typ. 


IVIax. 




V,L 


Input Low Voltage (All 
Except Xi, X2, RESET) 


-0.5 




0.8 


V 




V|L1 


Input Low Voltage (Xi, X2, 
RESET) 


-0.5 




0.6 


V 




V,H 


Input High Voltage (All 
Except Xi, X2, RESET) 


2.2 




Vcc 


V 




V,H1 


Input High Voltage (Xi, X2, 


3.8 




Vcc 


V 




Vol 


Output Low Voltage (D0-D7) 






0.45 


V 


loL= 2.0 mA 


V0L1 


Output Low Voltage (All 
Other Outputs) 






0.45 


V 


loL=1-6mA 


VOH 


Output High Voltage (D0-D7) 


2.4 






V 


loH=-400^A 


V0H1 


Output High Voltage (All 
Other Outputs) 


2.4 






V 


loH=-50/iA 


l|L 


Input Leakage Current 
(RD, WR, OS, Ao) 






±10 


mA 


Vss<V,N<Vcc 


loz 


Output Leakage Current 
(D0-D7, High Z State) 






±10 


mA 


Vss+ 0.45 <V|N< Vcc 


'dd 


Vdd Supply Current 




5 


15 


mA 




'dd-^'cc 


Total Supply Current 




60 


125 


mA 




Ili 


Low Input Load Current 
(Pins 24, 27-38) 






0.5 


mA 


V|L=0.8V 


Ilii 


Low Input Load Current 
(RESET) 






0.2 


mA 


V,L=0.8V 
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A.C. CHARACTERISTICS 

Ta=0°C to ZO-C, Vcc= Vdd=+5V± 10%, Vss = OV 



DBB READ 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAR 


CS, Ao Setup to RD 1 







ns 




tRA 


CS, Ao Hold After RD t 







ns 




tRR 


RD Pulse Width 


250 




ns 




tAD 


CS, Ao to Data Out Delay 




225 


ns 


Cl=150pF 


^RD 


RD i to Data Out Delay 




225 


ns 


Cl=150pF 


tDF 


RD t to Data Float Delay 




100 


ns 




tcY 


Cycle Time 


2.5 


15 


^s 





DBB WRiTE 



Symboi 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Uw 


CS, Ao Setup to WR I 







ns 




tWA 


CS, Ao Hold After WR t 


O 




ns 




tww 


WR Pulse Width 


250 




ns 




tow 


Data Setup to WR t 


150 




ns 




two 


Data Hold to WR t 







ns 




DIVIA AND INTERRUPT TliVIING 


Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Ucc 


DACK Setup to Control 







ns 




tcAC 


DACK Hold After Control 







ns 




tcRQ 


WR to DRQ Cleared 




200 


ns 




*ACD 


DACK to Data Valid 




225 


ns 





7-49 



8295 



WAVEFORMS 

1. READ OPERATION — OUTPUT BUFFER REGISTER. 



CS OR Ad 
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PRINTER INTERFACE TIMING AND WAVEFORMS 



MbTdA DRIVE 



SOLENOID DATA 



SOLENOID STROBE 



\ 



/ 



X 



— Sds 



-PDh-* 



;' ^^ 



1 



-Shs^ 



y 



\. 



^^ 



MHh 



PFElD 



PFM 



\ 



/ 



PHp 



\ 



/ 



Symbol 


Parameter 


Typical 


Pdh 


Print delay from 
home Inactive 


1.8 ms 


Sds 


Solenoid data 
setup time before 
strobe active 


25 /iS 


Shs 


Solenoid data 
hold after strobe 
Inactive 


>1 ms 


Mha 


Motor hold time 
after home active 


3.2 ms 


PSP 


PFEED setup time 
after PFM active 


58 ms 


Php 


PFM hold time 
after PFEED active 


9.75 ms 
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ICE-41A™ 
UPI-41A IN-CIRCUIT EMULATOR 



Extends Intellec microcomputer develop- 
ment system debug power to user con- 
figured system via external cable and 
40-pin plug, replacing user UPI-41A^'' 
devices 

Emulates user system UPI-41A^'' devices 
in real time 

Allows user configured system to use 
static RAM memory for program debug 

Provides hardware comparators for user 
designated brealc conditions 



Eliminates need for extraneous debug- 
ging tools residing In user system 

Collects address, data, and UPI-41A™ 
status Information on machine cycles 
emulated 

Provides capability to examine and alter 
UPi-41A^'' registers, memory, and flag 
values, and to examine pin and port 
values 

Integrates hardware and software efforts 
early In engineering cycle to save devel- 
opment time 



The ICE-41 A UPI-41 A In-Circuit Emulator module is an Intellec system resident module that interfaces to any user con- 
figured UPI-41A system. The ICE-41 A module Interfaces with a UPI-41 A pin-compatible plug which replaces the UPI- 
41 A device in the system. With the ICE-41A plug in place, the designer has the capability to execute the system in real 
time while collecting up to 255 instruction cycles of real time trace data. In addition, he can single step the system pro- 
gram during execution. Static RAM memory is available through the ICE-41A module to store UPI-41A programs. The 
designer may display and alter the contents of program memory, internal UPI-41A registers and flags, and I/O ports. 
Powerful debug capability Is extended into the UPI-41 A system while ICE-41 A debug hardware and software remain in- 
side the Intellec system. Symbolic reference capability allows the designer to use symbols rather than absolute values 
when examining and modifying memory, registers, flags, and I/O ports in the system. 
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FUNCTIONAL DESCRIPTION 

Debug Capability Inside User System 

Intellec memory is used for the execution of ttie ICE-41 A 
software. Tlie Inteliec CRT console and the fiie handling 
capabilities provide the designer with the ability to com- 
municate with the ICE-41A module and display informa- 
tion on the operation of the prototype system. The ICE- 
41 A module block diagram is shown in Figure 1. 



GO FROM .START TILL CODE. RSLT 

begins execution of the program at the address refer- 
enced by the label START in the designer's assembly 
program. A breakpoint Is set to occur the first time the 
microprocessor executes the program memory location 
referenced by RSLT. The designer does not have to be 
concerned with the physical locations of START and 
RSLT. The ICE-41 A software driver supplies them 
automatically from information stored in the symbol 
table. 



Symbolic Debugging 

Symbol Table— ICE-41A software allows the user to 
make symbolic references to I/O ports, memory ad- 
dresses, and data in his program. The user symbol table 
which is generated along with the object file during a 
program assembly can be loaded to Intellec memory for 
access during emulation. The user may add to this sym- 
bol table any additional symbolic values for memory ad- 
dresses, constants, or variables that he may find useful 
during system debugging. By referring to symbol 
memory addresses, the user can examine, change or 
break at the intended location. In addition, ICE-41 A pro- 
vides symbolic definition of all UPI-41A registers and 
flags. 

Symbolic Reference — Symbolic reference is a great 
advantage to the system designer. He is no longer 
burdened with the need to recall or look up addresses of 
key locations in his program which can change with 
each assembly. Meaningful symbols from his source 
program can be used instead. For example, the com- 
mand: 



IViemory Replacement 

The 8741/8741A and 8041/8041A contain internal pro- 
gram and data memory. When the UPI-41A microcom- 
puter is replaced by the ICE-41 A socket in a system, the 
ICE-41A module supplies static RAM memory as a 
replacement for the internal microcomputer memory. 
The ICE-41 A module has enough RAM memory available 
to emulate up to the total IK control memory capability 
of the system. 



Real-Time Trace 

The ICE-41A module captures trace information while 
the designer is executing programs in real time. The in- 
structions executed, program counter, port values for 
port 1 and port 2, and the values of selected UPI-41A 
status lines are stored for the last 255 instruction cycles 
executed. When retrieved for display, code Is dis- 
assembled for user convenience. This provides data for 
determining how the user system was reacting prior to 
emulating break. 
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Figure 1. ICE-41 A Modqle Block Diagram 
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Integrated Hardware/Software Development 

The user prototype systems need no more than a UPI- 
41A socket and timing logic to begin Integration of soft- 
ware and hardware development efforts. Through the 
ICE-41A module, Intellec system resources can be ac- 
cessed to replace the prototype system. UPI-41A soft- 
ware development can proceed without the prototype 
hardware. Hardware designs can be tested using 
previously tested system software. 

Hardware 

The ICE-41A module is a microcomputer system utiliz- 
ing Intel's UPI-41A microprocessor as its nucleus. This 
system communicates with the Intellec system 8080A 
processor via direct memory access. Host processor 
commands and ICE-41A status are Interchanged 
through a DMA channel. ICE-41A hardware consists of 
two printed circuit boards, the controller board and the 
emulator board, which reside In the Intellec system 
chassis. A cable assembly interfaces the ICE-41A 
module to the user's UPI-41A system. The cable ter- 
minates in a UPI-41A pin-compatible plug which 
replaces any UPI-41A device in the user system. 

Controller Board 

The ICE-41A module Interfaces to the Intellec systems 
as a peripheral device. The controller board receives 
commands from the Intellec system and responds 
through a DMA port. Three 10-bit hardware breakpoint 
registers are available which can be loaded by the user. 
While in emulation mode, a hardware comparator is con- 
stantly monitoring address lines for a match which will 
terminate an emulation. The controller board returns 
real-time trace data, UPI-41A registers, flag and port 
values, and status information to a control block in the 
Intellec system when emulation is terminated. This in- 
formation is available to the user through the ICE-41A 
interrogation commands. Error conditions, when 
detected, are automatically displayed on the Intellec 
system console. 

Emulator Board 

The emulator board contains the 8741 A and peripheral 
logic required to emulate the UPI-41A device in the user 
system. A 6 MHz clock drives the emulated UPI-41A 
device. This clock can be replaced with a user supplied 
TTL clock in the user system or can be strapped Inter- 
nally for 3 MHz operation. 

Cable Card 

The cable card is Included for cable driving. It transmits 
address and data bus information to the user system 
through a 40-pln connector which plugs Into the user 
system in the socket designed for the UPI-41A device. 

Software 

The ICE-41A software driver is a RAM-based program 
which provides the user with command language (see 
Table 1, Table 2, and Table 3) for defining breakpoints. 
Initiating real-time emulation or single step operation, 
and Interrogation and altering user system status 
recorded during emulation. The ICE-41A command 
language contains a broad range of modifiers which pro- 



vide the user with maximum flexibility in defining the 
operation to be performed. The ICE-41A software driver 
is available on diskette and operates in 32K of Intellec 
RAM memory. 



Command 


Operation 


Enable 

Go 

Step 

Interrupt 


Activates breakpoint and display reg- 
isters for use with go and step com- 
mands. 

Initiates real-time emulation and al- 
lows user to specify breakpoints and 
data retrieval. 

Initiates emulation in single instruc- 
tion increments. Each step is followed 
by register dump. User may optionally 
tailor other diagnostic activity to his 
needs. 

Emulates user system interrupt 



Table 1. ICE-41 A Emulation Commands 



Command 


Operation 


Display 

Change 

Base 
Suffix 


Prints contents of memory, UPI-41A 
device registers, I/O ports, flags, pins, 
real-time trace data, symbol table, or 
other diagnostic data on list device. 

Alters contents of memory, register, 
output port, or flag. Sets or alters 
breakpoints and display registers. 

Establishes mode of display for output 
data. 

Establishes mode of display for input 
data. 



Table 2. ICE-41 A interrogation Commands 



Command 


Operation 


Load 


Fetches user symbol table and object 
code from Input device. 


Save 


Sends user symbol table and object 
code to output device. 


Define 


Enters symbol name and value to user 
symbol table. 


Move 


Moves block of memory data to an- 
other area of memory. 


Print 


Prints user specified portion of trace 
memory to selected list device. 


List 


Defines list device. 


Exit 


Returns program control to ISIS-II. 


Evaluate 


Converts expression to equivalent val- 
ues in binary, octal, decimal, and hex. 


Remove 


Deletes symbols from symbol table. 


Reset 


Reinitializes ICE-41A hardware. 



Table 3. ICE-41 A Utility Commands 
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SPECIFICATIONS 

ICE-41A Operating Environment 

Required Hardware 

Intellec microcomputer development system 
System console 

intellec diskette operating system 
iCE-41A module 

Required Software 

System monitor 

ISIS-II 

ICE-41A diskette-based software 

System Clock 

Crystal controlled 6.0 MHz or 3.0 MHz internal or user 
supplied TTL external 

Physical Characteristics 
Printed Circuit Boards 

Width: 12.00 In. (30.48 cm) 

Height: 6.75 in. (17.15 cm) 

Depth: 0.50 in. (1.27 cm) 

Weight: 8.00 lb (3.64 kg) 

Cabie Buffer Box 

Width: 8.00 in. (20.32 cm) 
Height: 4.00 in. (10.16 cm) 
Depth: 1.25 in. (3.17 cm) 
Flat Cable: 4.00 ft (121.92 cm) 
User Cable: 15.00 in. (38.10 cm) 

Electrical Characteristics 
DC Power Requirements 

Vcc= +5V, ±5% 
lcc= lOA max; 8A typ 



Vdd= +12V, ±5% 

Idd= 100 ^A max; 60 mA typ 

Vbb=-10V 

Ibb = 30 mA 

input Impedance 

@ ICE-41A user socket pins: 

V|L=0.8V max; I|l= 1.6 mA 

V|H = 2.0V min; I|h = 40 mA 

@ Bus: 

V,L = 0.8V max; l,L = 250 mA 

V|H = 2.0Vmin;V|H=20MA 

Output impedance 

@ PI, P2: 

Vol = 0.5V max; Iql = 1 6 mA 

VoH = Vcc(10Kpullup) 

@ Bus: 

Vol = 0.5V max; Iol=25 mA 

VoH = 3.65V min; Ioh = 1 mA 

Others 

Vol = 0.5V r^iax; Iol= 16 mA 

VoH = 2.4V max; Iqh = 400 mA 

Equipment Supplied 

Controller board 

Emulator board 

Interface cables and buffer module 

Operator's manual 

ICE-41A diskette based software 

Reference Manuals 

9800465 - ICE-41A Operator's Manual (SUPPLIED) 
Reference manuals are shipped with each product only 
if designated SUPPLIED (see above). Manuals may be 
ordered from any Intel sales representative, distributor 
office or from Intel Literature Department, 3065 Bowers 
Avenue, Santa Clara, California 95051. 



ORDERING INFORMATION 
Part Number Description 

MDS-41A-ICE UPI-41A (8741, 8041, 8741A, 8041A) 

CPU 

In-circuit emulator, cable assembly 
and interactive diskette software 
included 
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MULTI-ICE™ SOFTWARE 
MULTIPLE-IN-CIRCUIT-EMULATOR 



Facilitates software and hardware debug- 
ging of multi-processor systems. 

Allows two In-Circuit Emulators to 
operate simultaneously in a single 
Intellec Microcomputer Development 
System. 

Provides enhanced software features: 
Symbolic Display of Addresses, Macro 
Commands, Compound Commands, 
Software Synchronization of Processes, 
and INCLUDE File Capability. 



Supports In-Circuit Emulator combina- 
tions, 85/85 Emulators, 85/49 Emulators 
(ICE-AS^*" Emulator supports the design 
using MCS-48'"" chip family), and 85/41 A 
Emulators. 

Functions under the supervision of ISIS- 
II Disk Operating System. 

Supports ICE-85^'' Emulator Hold 
Request/Hold Acknowledgement hand- 
shake while in both emulation and inter- 
rogation modes. (Can be used for 
Dynamic RAM refresh.) 



Mutti-ICE In-Circuit Emulator is a software product which allows two Intel In-Circuit Emulators to run simultaneously 
in a single Intellec Microcomputer Development System. Multi-ICE software used in lieu of the standard ICE software 
gives users full control of the Intellec Microcomputer Development System, and the two ICE modules for hardware 
and software debugging of multi-processor systems. 

Enhancement features available with Multi-ICE software include a compound command capability which enables the 
user to "program" a diagnostic or exercise sequence. Also included are repeat and conditional execution of ICE 
commands, and the ability to invoke the macro commands by name. 

A special EPROM set for the ICE-85 Emulator is included. The new firmware will enable the lCE-85 Emulator to support 
Hold-Request and Hold-Acknowledgement hand-shake protocol both while in emulation and while in interrogation 
mode. This allows the ICE-85 Emulator to support typical dynamic RAM and DMA applications. 




I ICE iCS. Insite. Intel. Intellec. iSBC, Library Manager, MCS. Megachassis. Micromap. Multibus. Multimodule. PROMPT. Promware. RMX. UPI. ^Scope. and the combination of 
ICE. iCS. (SBC, MCS, or RMX and a numerical suffix are trademarks of Intel Corporation, 
^ -/rife; Corporation 1979 
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MULTI-ICE OPERATION 

Multi-ICE software is a debug tool which allows two ICE 
emulators to begin and stop in sequence. Once started, 
two ICE emulators emulate simultaneously and 
independently. Thus, Multi-ICE software permits the 
debugging of asynchronous or synchronous multi- 
processor systems. 

A conceptual model for the Multi-ICE software can be 
illustrated with the following block diagram. 
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Block Diagram of Muiti-ICE^*^ Operation 



There are three processes in the Multi-ICE environ- 
ment: the Host process and the two ICE processes to 
control the two ICE hardware modules. The processor 
for these three processes is the microcomputer in the 
Intellec Microcomputer Development System. Only the 
Host process is active when Multi-ICE software is 
invoked. The Parser interfaces with the console, 
receives commands from the console or from a file, 
translates them into intermediate code, and loads the 
code into the Host command code buffer or ICE com- 
mand code buffers. 

The Host process executes commands from its com- 
mand code buffer using the execution software and 
hardware of the Host's current environment, either 
environment 1 or environment 2 (EN1 or EN2), as 
required. EN1 and EN2 are the operating environments 
of the two In-Circuit Emulators. 

The user can change the execution environment (from 
EN1 to EN2 or vice versa) with the SWITCH command. 
Once the environment is selected, ICE operation is the 
same as with standard ICE software. In addition, the 
enhanced software capabilities are available to the 
user. 

The two ICE processes (PR1 and PR2) execute com- 
mands from their command code buffers in their own 
environments (PR1 in EN1 and PR2 in EN2). The main 
functions of the two ICE execution processes are to 
control the operations of the two ICE hardware sets. 
The ACTIVATE command controls the execution of the 
ICE processes. Commands are passed on to each ICE 
unit to initiate the desired ICE functions. 

The two ICE hardware units accept commands from the 
Host process or ICE processes. Once emulations start, 
the two ICE hardware sets will operate until a break con- 
dition is met or processing is interrupted by commands 
from the ICE execution processes. 



ENHANCED DIAGNOSTIC SOFTWARE 
FUNCTIONS 

Single ICE^*' Module Operation 

Multi-ICE software can be used for single ICE operation. 
The operating procedures will be identical to the Multi- 
ICE operation. All the enhanced software functions will 
be available. The performance will be the same as if the 
standard ICE software is being used. 



Symbolic Display of Addresses 

The user has the option of displaying a 16-bit address in 
the form of a symbol name or line number plus a hex 
number offset. 

Macro Command 

A macro is a set of commands which is given a name. 
Thus, a group of commands which is executed fre- 
quently may be defined as a macro. Each time the user 
wants to execute that group of commands, he may just 
invoke the macro by typing a colon followed by the 
macro name. Up to ten parameters may be passed to 
the macro. 

Macro commands may be defined at the beginning of a 
debug session and then can be used throughout the 
whole session. If the user wants to save the macros for 
later use, he may use the PUT command to save the 
macro on diskette, or the user may edit the macro file 
off-line using the Intellec text editor. Later, the user 
may use the INCLUDE command to bring in the macro 
definition file that he created. 



Example: 
*DEFINE MACRO INITMEM 



.*SWITCH = EN1 



* BYTE TGI 00=0 
*L0AD:F1:DRIVER 



*SWITCH = EN2 



.*L0AD:F1:DR2 



.*EM 



;This macro clears the 
memory and then loads the 
programs. 

;Select environment 1 (ICE 
Module 1) 

;lnitialize memory to 0. 
;Load user program into 
memory for ICE Module 1 . 
;Select environment 2 (ICE 
Module 2) 

;Load user program into 
memory for ICE Module 2. 
;End of Macro 

;To execute this Macro, user 
types :INITMEM 



Compound Command 

Compound commands provide conditional execution of 
commands (IF Command) and execution of commands 
repeatedly until certain conditions are met (COUNT, 
REPEAT Commands). 

Compound commands and Macro commands may be 
nested any number of times. 

Example: 



*DEFINE.I = 
*COUNT100H 



.MF.IAND1THEN 
..*BYT.I = .I 



..*END 
.M = .l+1 
*END 



;Define symbol .1 toO 
jRepeat the following 
commands 100H times. 
;Check if .1 is odd 
;Fill the memory at location .1 
to value .1 

;lncrement .1 by 1. 
;Command executes upon 
carriage-return after END 



8-6 



MULTMCE^^ SOFTWARE 



Software Synchronization of Processes 

Up to three processes (Host, PR1 and PR2) can be 
active simultaneously in the system. An ICE process 
can be activated (ACTIVATE), suspended (SUSPEND), 
killed (KILL), or continued (CONTINUE). The Host pro- 
cess can wait for other processes to become dormant 
before it becomes active again. Through these syn- 
chronization commands, the user can create a system 



test file off-line yet be able to synchronize the three pro- 
cesses when the actual system test is executed. 

Example: 

The capability of the software synchronization com- 
mands is demonstrated by the following example. The 
flowchart shows the synchronization requirements. The 
program steps show the actual implementation. 



PROCESSOR 1 


HOST PROCESSOR 


PROCESSOR 2 


1 

PROCESSOR 1 1 
DORMANT 

1 

1 ACTIVE 





ACTIVE 




l*R0CESSORZ 
1 DORMANT 


1 ACTIVATE PROCESSOR 1 | 


* 


1 GO FOREVER | 


1 SWITCH TO ENVIRONMENT 1 
1 FOR PROCESSOR 2 1 


PROCESSOR 1 
ACTIVE 

PROCESSOR 1 
DORMANT 
















f 

^X^REPEAT^Ss. 
^^^ WHILE PC OF ^S^NO 
"^ PROCESSOR 2 ^ 

^Ss^i^ .LOOP^X*^ 

YES 





1 ACTIVATE PROCESOR 2 | 








\ 














GO TILL INSTRUCTIONS AT 

LOCATION .LOOP OR 

END IS EXECUTED 






WAIT UNTIL 
PROCESSOR 2 
IS DORMANT 







\ 




HOST PRO 


CESSOR I 








IS IN WAIT 

NO y^ 


r STATE ! 

•^ IF PC ^S^ 

OF ^*^ 
PROCESSOR 2 ^ 


1 DISPLAY REGISTER 1 

i 




— 






^^.^^ = .LOOP^^^ 

Tyes 


1 
1 




1 SUSPEND PROCESSOR 1 1 


PROCESSOR 2 
1 DORMANT 

1 


' 












PRO 


HOST 
CESSOR 
ACTIVE 








1 
1 





Flowchart of the Example for Demonstrating Multi-ICE' "^ Synchronization Capability 



* ACTIVATE PR1 

.*G0 FROM 800 

.*END 

PR1 EMULATION BEGUN 

*SWI=EN2 

*REPEAT 

WHILE PC < >.LOOP 

'ACTPR2 

*G0 TILL. LOOP OR .END 

*REGISTER 

*END 

'WAIT PR2 

IF PC=. LOOP THEN 

*SUSPENDPR1 

*END 

'END 



;Activate PR1 
;Start ICE Module 1 
;End of Activate block 

.Switch execution Environment to EN2 

;Repeat the following block of commands while PC Is not equal to .Loop 

;Activate PR2 

;Go till instruction at location .Loop or at location .END is executed 

;Display the registers 

;End of Activate block 

;Wait until PR2 is dormant 



.EndoflFblock 

;End of REPEAT block 
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MULTI-ICE'^ SOFTWARE 



INCLUDE File Capability 

The INCLUDE command causes input to be taken from 
the file specified until the end of the file is encountered, 
at which point, input continues to be taken from the 
previous source. Nesting of INCLUDES is permitted. 
Since the command code file can be complex, the 
ability to edit offline becomes desirable. The INCLUDE 
command allows the user to pull in command code files 
and Macro commands created offline which can then be 
used for the particular debugging session. 



Example: 
INCLUDE :F1:PR0G1 
*MAPO LENGTH 64K=USER 



*MAPIO0TOFF = USER 
*SWITCH = EN2 
*L0AD:F2:LED.HEX 
*SWITCH = EN1 



;Cause input to be taken 
from file PR0G1 
;Contents of the file PR0G1 
are listed on screen as they 
are executed. 



;EndofthefilePROG1 
jAftertheend of file is 
reached, control is returned 
to console. 



SPECIFICATIONS 
Equipment Supplied: 

— Multi-ICE Flexible diskettes 

(one each in single and double density) 
Contains software that supports 85/85 Emulators, 
85/49 Emulators, and 85/41A Emulators 

— Special EPROM set for one ICE-85 Emulator 

— Operator's Manual 

MULTMCE'" OPERATING ENVIRONMENT 

Required Hardware: 

Intellec Microcomputer Development System 

-Model-800, Model-888 

—Series II Model 220, Model 230, and Expansion 
Chassis 



Required Hardware: (Cont'd.) 

64K bytes of RAM memory 

Flexible disk drive(s) 

—Single or double density 

System Console 

—CRT or hard copy interactive device 

ICE-85 Emulator(s), ICE-49 Emulator or ICE-41A 
Emulator 

Optional Hardware: 

Printer 

Additional flexible disk drives 

Required Software: 

Intel Systems Implementation Supervisor (ISIS-II 



ORDERING INFORMATION: 



Product Code 
MDS*-350 



Description 
Multi-ICE Software 



*"MDS" is used as an ordering code only, and is not used as a product name or trademark. MDS® is a registered trade- 
mark of Mohawk Data Sciences Corp. 
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DISKETTEBASED SOFTWARE 
SUPPORT PACKAGE 



Extends Intellec® Microcomputer Development 



,TM 



System to support MCS-48 development 

Takes advantage of powerful ISIS-II file handling 
and storage capabilities 



IVICS-48 Assembler provides conditional assem- 
bly and macro capability 



The MCS-48"^^ Diskette-based Software Support Package (MDS-D48) comes on an Intel® ISIS-II Systenn Diskette and 
contains the MCS-48 Assembler (ASM48), and the diskette version of the Universal PROM Mapper. 

The MCS-48 Assembler (ASM48) translates symbolic 8048 assembly language instructions into the appropriate 
machine operation codes. In addition to eliminating the errors of hand translation, the ability to refer to program ad- 
dresses with symbolic names makes it easier to modify programs when adding or deleting instructions. Conditional 
assembly permits the programmer to specify portions of the master source document which should be included or 
deleted In variations on a basic system design, such as the code required to handle optional external devices. 

Macro capability allows the programmer to define a routine through the use of a single label. ASM48 will assemble the 
code required by the reserved routine whenever the Macro label is Inserted in the text. 

Output from the ASM48 is In standard Intel® Hex format. It may be loaded directly to an ICE-48 module for integrated 
hardware/software debugging. It may also be loaded Into the Intellec Development System for 8748 PROM programm- 
ing using the Universal PROM Programmer. 







i^Bpr 



l^^^^^^^^^^fi^^i^wpP^jpiiiili! 
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MCS-48™ DISKETTE-BASED SOFTWARE SUPPORT PACKAGE 



FUNCTIONAL DESCRIPTION 

The MCS-48 assembler translates symbolic 8048 
assembly language Instructions into the appropriate 
machine operation codes. The ability to refer to program 
addresses with symbolic names eliminates the errors of 
hand translation and mal<es It easier to modify programs 
when adding or deleting instructions. Conditional 
assembly permits the programmer to specify which por- 
tions of the master source document should be includ- 
ed or deleted in variations on a basic system design, 
such as the code required to handle optional external 
devices. Macro capability allows the programmer use of 
a single label to define a routine. The MCS-48 assembler 
will assemble the code required by the reserved routine 
whenever the macro label is inserted in the text. Output 
from the assembler Is in standard Intel hex format. It 
may be either loaded directly to an In-circult emulator 
(ICE-49) module for Integrated hardware/software 
debugging, or loaded into a Universal PROM Program- 
mer for 8748 PROM programming. A sample assembly 
listing is shown In Table 1. 



ISIS-II 8048 MACROASSEMBLER, VI .0 






PAGE 1 1 


LOG 


OBJ 




SEQ 




SOURCE STATEMENT 1 








1 


DECIMAL ADDITION ROUTINE. ADD BCD NUMBER j 








2 


AT LOCATION 'BETA 


TO BCD NUMBER AT 'ALPHA' WITH 








3 


RESULT 


N -ALPHA.' 


LENGTH OF NUMBER IS 'COUNT' DIGIT 










PAIRS. (ASSUME BOTH BETA AND ALPHA ARE SAME LENGTH 1 










AND HAVE EVEN NUMBER OF DIGITS OR MSD IS IF | 








6 


ODD) 












8 
9 


NIT 


MACRO 

MOV 

MOV 


AUGND,ADDND,CNT 
RO, #AUGND 
R1,#ADDND 








10 




MOV 
ENDM 


R2, #CNT 


0001 E 






13 


ALPHA 


EQU 


30 


0028 








BETA 


EQU 


40 


0032 






15 


COUNT 


EQU 


5 


0100 






16 




ORG 
INIT 


100H 

ALPHA, BETA, COUNT 


0100 


B81E 




18 + 




MOV 


RO, #ALPHA 


0102 


B928 




19+L 




MOV 


R1,#BETA 


0104 


BA32 








MOV 


R2, #COUNT 


0106 


97 




21 




CLR 


C 


0107 


FO 






LP: 


MOV 


A, ®R0 


0108 


71 




23 




ADDC 


A, @R1 


0109 


57 




24 




DA 




01 OA 






25 




MOV 


@R0, A 


010B 


18 




26 




INC 


RO 


010C 


19 




27 




INC 


R1 


010D 


EA07 




28 




DJNZ 
END 


R2, LP 


USER SYMBOLS 












ALPHA 0001 E BETA 0028 


COUNT 0005 


LP 0107 




LI 


0102 












ASSEMBLY COMPLETE 


NO ERRORS 








ISIS-I 


ASSEMBLER SYMBOL CROSS REFERENCE, 


V1.0 


PAGE1 


SYMBOL CROSS REFERENCE 










ALPHA 13# 17 












BETA 


14# 17 












COUNT 15# 17 














7# 17 














19# 












LP 


22# 28 













Table 1. Sample MCS-48 Diskette-Based 
Assembly Listing 



SPECIFICATIONS 

Operating Environment 

Required Hardware 

Intellec Microcomputer Development System 
32K RAM (non-macro use) 
48K RAM (use of macro facility) 
One or two Floppy disk drives 

— Single or Double density 
System Console 

— CRT or Interactive hardcopy device 

Required Software 

ISIS-II Diskette Operating System 

Optional Hardware 

ICE-49 In-Cjrcult Emulator 

Line Printer 

Universal PROM Programmer with 8748 personality card 



Sliipping IVIedia 

Diskette 

Reference IVIanuals 

9800255 — MCS-48 and UPI-41 Assembly Language Pro- 
gramming Manual (SUPPLIED) 

9800236 — Universal PROM Mapper Operator's Manual 
9800306 — ISIS-II User's Guide 



Reference manuals are shipped with each product only 
if designated SUPPLIED (see above). Manuals may be 
ordered from any Intel sales representative, distributor 
office or from Intel Literature Department, 3065 Bowers 
Avenue, Santa Clara, California 95051. 



ORDERING INFORMATION 

Product Code Description 

MDS-D48 Diskette-based assembler for MCS-48 

family of microprocessors. 
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Intel 



MODEL 230 

INTELLEC® SERIES II 

MICROCOMPUTER DEVELOPMENT SYSTEM 



Complete microcomputer development 
center for Intel 80/85, 8086, and 8048 
microprocessor families 

LSI electronics board with CPU, RAM, 
ROM, I/O, and interrupt circuitry 

64K bytes RAM memory 

Self-test diagnostic capability 

Eight-level nested, maskable priority 
interrupt system 

Built-in interfaces for high speed paper 
tape reader/punch, printer, and universal 
PROM programmer 

Integral CRT with detachable upper/ 
lower case typewriter-style full ASCII 
keyboard 



Powerful ISIS-II Diskette Operating 
System software with relocating 
macroassembler, linker, and locater 



1 million bytes (expandable to 2.5M 
bytes) of diskette storage 

Supports PL/M and FORTRAN high level 
languages 



Standard MULTIBUS™ with 
multiprocessor and DMA capability 

Compatible with standard Intellec/iSBC™ 
expansion modules 



Software compatible with previous 
Intellec® systems 



The Model 230 Intellec Series II Microcomputer Development System is a complete center for the development of 
microcomputer-based products. It includes a CPU, 64K bytes of RAM, 4K bytes of ROM memory, a 2000-character CRT, 
a detachable full ASCII keyboard, and dual double density diskette drives providing over 1 million bytes of on-line data 
storage. Povi/erful ISIS-II Diskette Operating System software allows the Model 230 to be used quickly and efficiently 
for assembling and/or compiling and debugging programs for Intel's 80/85, 8086, or 8048 microprocessor 
families without the need for handling paper tape. ISIS-II performs all file handling operations, leaving the user free to 
concentrate on the details of his own application. When used in conjunction with an optional in-circult emulator (ICE) 
module, the Model 230 provides all the hardware and software development tools necessary for the rapid development 
of a microcomputer-based product. 
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MODEL 230 



FUNCTIONAL DESCRIPTION 

Hardware Components 

The Intellec Series II Model 230 is a packaged, highly 
Integrated microcomputer development system consist- 
ing of a CRT chassis with a 6-slot cardcage, power sup- 
ply, fans, cables, and five printed circuit cards. A 
separate, full ASCII keyboard is connected with a cable. 
A second chassis contains two floppy disk drives capa- 
ble of double-density operation along with a separate 
power supply, fans, and cables for connection to the 
main chassis. A block diagram of the Model 230 Is 
shown in Figure 1. 

CPU Cards — The master CPU card contains its own 
microprocessor, memory, I/O, Interrupt and bus Inter- 
face circuitry fashioned from Intel's high technology LSI 
components. Known as the integrated processor board 
(IPB), it occupies the first slot In the cardcage. A second 
slave CPU card is responsible for all remaining I/O con- 
trol including the CRT and keyboard Interface. This card, 
mounted on the rear panel, also contains its own micro- 
processor, RAM and ROM memory, and I/O interface 
logic, thus, In effect, creating a dual processor environ- 
ment. Known as the I/O controller (IOC), the slave CPU 



card communicates with the IPB over an 8-bit bidirec- 
tional data bus. 

Memory and Control Cards — In addition, 32K bytes of 
RAM (bringing the total to 64K bytes) is located on a 
separate card In the main cardcage. Fabricated from 
Intel's 16K RAMs, the board also contains all necessary 
address decoding and refresh logic. Two additional 
boards in the cardcage are used to control the two 
double-density floppy disk drives. 

Expansion — Two remaining slots In the cardcage are 
available for system expansion. Additional expansion of 
4 slots can be achieved through the addition of an Intel- 
lec Series II expansion chassis. 

System Components 

The heart of the IPB is an Intel NMOS 8-bJt microproces- 
sor, the 8080A-2, running at 2.6 MHz. 32K bytes of RAM 
memory are provided on the board using Intel 16K 
RAMs. 4K of ROM is provided, preprogrammed with sys- 
tem bootstrap "self-test" diagnostics and the Intellec 
Series II System Monitor. The eight-level vectored prior- 
ity interrupt system allows interrupts to be Individually 
masked. Using Intel's versatile 8259 Interrupt controller, 
the interrupt system may be user programmed to 
respond to Individual needs. 
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Figure 1. Intellec Series II Model 230 Microcomputer Development System Block Diagram 
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MODEL 230 



Input/Output 

IPB Serial Channels — The I/O subsystem in the Model 
230 consists of two parts: the IOC card and two serial 
channels on the IPB itself. Each serial channel is RS232 
compatible and is capable of running asynchronously 
from 11 to 9600 baud or synchronously from 1 50 to 56K 
baud. Both may be connected to a user defined data set 
or terminal. One channel contains current loop 
adapters. Both channels are implemented using Intel's 
8251 USART. They can be programmatically selected to 
perform a variety of I/O functions. Baud rate selection is 
accomplished progammatically through an Intel 8253 
interval timer. The 8253 also serves as a real-time clock 
for the entire system. I/O activity through both serial 
channels is signaled to the system through a second 
8259 interrupt controller, operating in a polled mode 
nested to the primary 8259. 

IOC Interface — The remainder of system I/O activity 
takes place in the IOC. The IOC provides interface for 
the CRT, keyboard, and standard Intellec peripherals 
including printer, high speed paper tape reader/punch, 
and universal PROM programmer. The IOC contains its 
own independent microprocessor, also an 8080A-2. The 
CPU controls all I/O operations as well as supervising 
communications with the IPB. 8K bytes of ROM contain 
all I/O control firmware. 8K bytes of RAM are used for 
CRT screen refresh storage. These do not occupy space 
in Intellec Series 11 main memory since the IOC is a 
totally independent microcomputer subsystem. 

Integral CRT 

Display — The CRT is a 12-inch raster scan type monitor 
with a 50/60 Hz vertical scan rate and 15.5 kHz horizontal 
scan rate. Controls are provided for brightness and con- 
trast adjustments. The interface to the CRT is provided 
through an Intel 8275 single chip programmable CRT 
controller. The master processor on the IPB transfers a 
character for display to the IOC, where it is stored in 
RAM. The CRT controller reads a line at a time into its 
line buffer through an Intel 8257 DMA controller and 
then feeds one character at a time to the character gen- 
erator to produce the video signal. Timing for the CRT 
control is provided by an Intel 8253 interval timer. The 
screen display is formatted as 25 rows of 80 characters. 
The full set of ASCII characters are displayed, including 
lower case alphas. 

Keyboard — The keyboard interfaces directly to the IOC 
processor via an 8-bit data bus. The keyboard contains 
an Intel UPI-41 Universal Peripheral Interface, which 
scans the keyboard, encodes the characters, and buf- 
fers the characters to provide N-key rollover. The key- 
board itself is a high quality typewriter style keyboard 
containing the full ASCII character set. An upper/lower 
case switch allows the system to be used for document 
preparation. Cursor control keys are also provided. 

Peripheral Interface 

A UPI-41 Universal Peripheral Interface on the IOC board 
performs similar functions to the UPI-41 on the PIO 
board in the Model 210. It provides interface for other 
standard Intellec peripherals including a printer, high 
speed paper tape reader, high speed paper tape punch, 



and universal PROM programmer. Communication 
between the IPB and IOC is maintained over a separate 
8-blt bidirectional data bus. Connectors for the four 
devices named above, as well as the two serial chan- 
nels, are mounted directly on the IOC itself. 

Control 

User control is maintained through a front panel, con- 
sisting of a power switch and indicator, reset/boot 
switch, run/halt light, and eight interrupt switches and 
indicators. The front panel circuit board is attached 
directly to the IPB, allowing the eight interrupt switches 
to connect to the primary 8259, as well as to the Intellec 
Series II bus. 

Diskette System 

The Intellec Series II double density diskette system 
provides direct access bulk storage, intelligent control- 
ler, and two diskette drives. Each drive provides V2 mil- 
lion bytes of storage with a data transfer rate of 500,000 
bits/second. The controller is implemented with Intel's 
powerful Series 3000 Bipolar Microcomputer Set. The 
controller provides an interface to the Intellec Series II 
system bus, as well as supporting up to four diskette 
drives. The diskette system records all data in soft sec- 
tor format. The diskette system is capable of performing 
seven different operations: recalibrate, seek, format 
track, write data, write deleted data, read data, and verify 
CRC. 

Diskette Controller Boards — The diskette controller 
consists of two boards, the channel board and the inter- 
face board. These two PC boards reside in the Intellec 
Series II system chassis and constitute the diskette 
controller. The channel board receives, decodes and 
responds to channel commands from the 8080A-2 CPU 
in the Model 230. The interface board provides the 
diskette controller with a means of communication with 
the diskette drives and with the Intellec system bus. The 
interface board validates data during reads using a 
cyclic redundancy check (CRC) polynomial and gener- 
ates CRC data during write operations. When the disk- 
ette controller requires access to Intellec system mem- 
ory, the interface board requests and maintains DMA 
master control of the system bus, and generates the 
appropriate memory command. The interface board also 
acknowledges I/O commands as required by the Intellec 
bus. In addition to supporting a second set of double 
density drives, the diskette controller may co-reside 
with the Intel single density controller to allow up to 2.5 
million bytes of on-line storage. 

MULTIBUS Capability 

All Intellec Series II models implement the industry 
standard MULTIBUS. MULTIBUS enables several bus 
masters, such as CPU and DMA devices, to share the 
bus and memory by operating at different priority levels. 
Resolution of bus exchanges is synchronized by a bus 
clock signal derived independently from processor 
clocks. Read/write transfers may take place at rates up 
to 5 MHz. The bus structure is suitable for use with any 
Intel microcomputer family. 
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MODEL 230 



SPECIFICATIONS 

Host Processor (IPB) 

RAM — 64K (system monitor occupies 62K through 64K) 
ROM — 4K (2K in monitor, 2K in boot/diagnostic) 

Diskette System Capacity (Basic Two Drives) 

Unformatted 

Per Disk: 6.2 megabits 

Per Track: 82.0 kilobits 

Formatted 

Per Disk: 4.1 megabits 

Per Track: 53.2 kilobits 

Dislcette Performance 

Diskette System Transfer Rate — 500 kilobits/sec 

Diskette System Access Time 

Track-to-Track: 10 ms 

Head Settling Time: 10 ms 

Average Random Positioning Time — 260 ms 

Rotational Speed — 360 rpm 

Average Rotational Latency — 83 ms 
Recording Mode — M^FM 

Physical Characteristics 

Width - 17.37 in. (44.12 cm) 
Heigiit — 15.81 in. (40.16 cm) 
Depth — 19.13 in. (48.59 cm) 
Weight - 73 lb (33 kg) 
Keyboard 

Width -. 17.37 in. (44.12 cm) 
Height — 3.0 in. (7.62 cm) 
Depth — 9.0 in. (22.86 cm) 
Weight - 6 lb (3 kg) 
Dual Drive Chassis 
Width - 16.88 in. (42.88 cm) 
Height — 12.08 in. (30.68 cm) 
Depth — 19.0 in. (48.26 cm) 
Weight - 64 lb (29 kg) 

Electrical Characteristics 
DC Power Supply 



Volts 


Amps 


Typical 


Supplied 


Supplied 


System Requirements 


+ 5 ±5% 


30 


14.25 


+ 12 ±5% 


2.5 


0.2 


-12 ±5% 


0.3 


0.05 


-10 ±5% 


1.5 


15 


+ 15 ±5% 


1.5 


1.3 


+ 24 ±5% 


1.7 





*Not available on bus. 



AC Requirements — 50/60 Hz, 115/230V AC 



Environmental Characteristics 

Operating Temperature — OMo 35°C (95 "F) 



Equipment Supplied 

Model 230 chassis 

Integrated processor board (IPB) 

I/O controller board (IOC) 

32 K RAM board 

CRT and keyboard 

Double density floppy disk controller (2 boards) 

Dual drive floppy disk chassis and cables 

2 floppy disk drives (512K byte capacity each) 

ROM-resident system monitor 

ISIS-II system diskette with MCS-80/MCS-85 
macroassembler 



Reference Manuals 

9800558 — A Guide to Microcomputer Development 

Systems (SUPPLIED) 

9800560 -- Intellec Series II Installation and Service 

Guide (SUPPLIED) 

9800306 - ISIS-II System User's Guide (SUPPLIED) 

9800556 — Intellec Series II Hardware Reference Man- 
ual (SUPPLIED) 

9800555 — Intellec Series II Hardware Reference Man- 
ual (SUPPLIED) 

9800301 — 8080/8085 Assembly Language Program- 
ming Manual (SUPPLIED) 

9800292 — ISIS-II 8080/8085 Assembler Operator's Man- 
ual (SUPPLIED) 

9800605 — Intellec Series II Systems Monitor Source 
Listing (SUPPLIED) 

9800554 — Intellec Series II Schematic Drawings 
(SUPPLIED) 

Reference manuals are shipped with each product only 
if designated SUPPLIED (see above). Manuals may be 
ordered from any Intel sales representative, distributor 
office or from Intel Literature Department, 3065 Bowers 
Avenue, Santa Clara, California 95051. 



ORDERING INFORMATION 
Part Number Description 

MDS-230 Intellec Series II Model 230 

microcomputer development system 
(110V/60 Hz) 

MDS-231 Intellec Series II Model 230 

microcomputer development system 
(220V/50 Hz) 



8-14 



iny 



UPP-103* 
UNIVERSAL PROM PROGRAMMER 

* Replaces UPP-101, UPPfOZ Universal PROM Programmers 



Intellec® development system peripheral 
for PROM programming and verification 



Provides personality cards for program- 
ming all Intel PROM families 



Provides zero insertion force soclcets for 
both 16-pin and 24-pin PROMs 



Universal PROM mapper software pro- 
vides powerful data manipulation and 
programming commands 

Provides flexible power source for 
system logic and programming pulse 
generation 

IHolds two personality cards to facilitate 
programming operations using several 
PROM types 



The UPP-103 Universal PROM Programmer is an Intellec system peripheral capable of programming and verifying all of 
the Intel programmable ROMs (PROMs). In addition, the UPP-103 programs the PROM memory portions of the 8748 
microcomputer, 8741 UPI, the 8755 PROM and I/O chip and the 2920 signal processor. Programming and verification 
operations are initiated from the Intellec development system console and are controlled by the universal PROM map- 
per (UPM) program. 
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UPP-103 



FUNCTIONAL DESCRIPTION 

Universal PROM Programmer 

The basic Universal PROM Programmer (UPP) consists 
of a controller module, two personality card sockets, a 
front panel, power supplies, a chassis, and an Intellec 
development system interconnection cable. An Intel 
4040-based intelligent controller monitors the com- 
mands from the Intellec System and controls the data 
transfer interface between the selected PROM persona- 
lity card and the Intellec memory. A unique personality 
card contains the appropriate pulse generation func- 
tions for each Intel PROM family. Programming and veri- 
fying any Intel PROM may be accomplished by selecting 
and plugging in the appropriate personality card. The 
front panel contains a power-on switch and indicator, a 
reset switch, and two zero-force insertion sockets (one 
16-pin and one 24-pin or two 24-pin). A central power 
supply provides power for system logic and for PROM 
programming pulse generation. The Universal PROM 
Programmer may be used as a table top unit or mounted 
in a standard 19-inch RETMA cabinet. 



Universal PROM Mapper 

The Universal PROM Mapper (UPM) is the software pro- 
gram used to control data transfer between paper tape 
or diskette files and a PROM plugged into the Universal 
PROM Programmer. It uses Intellec system memory for 
intermediate storage. The UPM transfers data in 8-bit 
HEX, BNPF, or binary object format between paper tape 
or diskette flies and the Intellec system memory. While 
the data is in Intellec system memory. It can be dis- 
played and changed. In addition, word length, bit posi- 
tion, and data sense can be adjusted as required for the 
PROM to be programmed. PROMs may also be dupli- 
cated or altered by copying the PROM contents into the 
Intellec system memory. Easy to use program and com- 
pare commands give the user complete control over pro- 
gramming and verification operations. The UPM elimi- 
nates the need for a variety of personalized PROM pro- 
gramming routines because it contains the program- 
ming algorithms for all Intel PROM families. The UPM 
(diskette based version) is included with the Universal 
PROM Programmer. 



SPECIFICATIONS 

Hardware Interface 

Data — Two 8-bit unidirectional buses 

Commands — 3 write commands, 2 read commands, 

one initiate command 

Physical Characteristics 
width — 6 in. (14.7 cm) 
Height — 7 in. (17.2 cm) 
Depth — 17 in. (41.7 cm) 
Weight - 18 lb (8.2 kg) 

Electrical Characteristics 

AC Power Requirements — 50-60 Hz; 1 15/230V AC: 80W 

Environmental Characteristics 
operating Temperature — O'C to 55*0 

Optional Equipment 
Personality Cards 

UPP-816: 2716 personality card 

UPP-833: 2732, 2732A personality card 

UPP-848: 8748, 8741 personality card with 40-pin adaptor 

socket 

UPP-866: 3602, 3622, 3602A, 3622A, 3621, 3604, 3624, 

3604A, 3624A, 3604AL, 3604A-6, 3605, 3605A, 3625, 

3625A, 3608, 3628, 3636 

UPP-872: 8702A/1702A personality card 

UPP-878: 8708/8704/2708/2704 personality card 



UPP-955: 8755A personality card with 40-pin adaptor 
socket 

PROM Programming Sockets 

UPP-501: 16-pin/24-pin socket pair 

UPP-502: 24-pin/24-pin socket pair 

UPP-562: Socket adaptor for 3621, 3602, 3622, 3602A, 

3622A 

UPP-555: Socket adaptor for 3604AL, 3604A-6, 3608, 

3628, 3636 

UPP-566: Socket adaptor for 3605, 3605A, 3625, 3625A 



Equipment Supplied 

Cabinet 
Power supplies 

4040 intelligent controller module 
Specified zero insertion force socket pair 
Intellec development system interface cable 
Universal PROM Mapper program (diskette-based ver- 
sion) 



Reference Manuals 

9800819 — Universal PROM Programmer User's Manual 
(SUPPLIED) 



ORDERING INFORMATION 

Part Number Description 

UPP-103 Universal PROM programmer with 

16-pin/24-pin socket pair and 
24-pin/24-pin socket pair. 
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3065 Bowers Avenue 
Santa Clara, California 95051 
Tel: (408)987-8080 
TWX: 910-338-0026 
TELEX: 34-6372 

ALABAMA 

Intel Corp. 

3322 S. Parkway, Ste. 71 
Holiday Office Center 
Huntsville 35802 
Tel: (205)863-2430 
Pen-Tech Associates, Inc. 
Holiday Office Center 
3322 Memorial Pkwy., S.W. 
Huntsville 35801 
Tel: (205)881-9298 

ARIZONA 

Intel Corp. 

10210 N. 25th Avenue, Suite 11 

Phoenix 85021 

Tel: (602)997-9695 

BFA 

4426 North Saddle Bag Trail 

Scottsdale 85251 

Tel: (602)994-5400 

CALIFORNIA 

Intel Corp. 

7670 Opportunity Rd. 
Suite 135 
San Oiego 92111 
Tel: (714)268-3563 
Intel Corp.* 
1651 East 4th Street 
Suite 105 
Santa Ana 92701 
Tel; (714)835-9642 
TWX: 910-595-1114 
Intel Corp.* 
15335 Morrison 
Suite 345 

Sherman Oaks 91403 
Tel: (213)986-9510 
TWX 910-495-2045 
Intel Corp.* 
3375 Scott Blvd. 
Santa Clara 95051 
Tel: (406)987-8086 
TWX: 910-339-9279 
910-338-0255 
Earle Associates, Inc. 
4617 Ruffner Street 
Suite 202 
San Diego 92111 
Tel: (714)278-5441 
Mac-I 

2576 Shattuck Ave. 
Suite 4B 
Berkeley 94704 
Tel: (415)843-7625 
Mac-I 

P.O. Box 1420 
Cupertino 95014 
Tel: (408)257-9880 

Mac-I 

11725 Espen Circle 

P.O. Box 8763 

Fountain Valley 92708 

Tel: (714)839-3341 

Mac-I 

1321 Centinela Avenue 
Suite 1 

Santa Monica 90404 

Tel: (213)829-4797 

Mac-I 

20121 Ventura Blvd., Suite 240E 

Woodland Hills 91364 

Tel: (213)347-5900 

COLORADO 

Intel Corp.* 
650 S. Cherry Street 
Suite 720 
Denver 80222 
Tel: (303)321-8086 
TWX: 910-931-2289 
Westek Data Products, Inc. 
25921 Fern Gulch 
P.O. Box 1355 
Evergreen 80439 
Tel: (303)674-5255 
Westek Data Products, Inc. 

1322 Arapahoe 
Boulder 80302 
Tel: (303)449-2620 
Westek Data Products, Inc. 
1228 W. Hinsdale Dr. 
Littleton 60120 

Tel: (303)797-0482 

CONNECTICUT 

Intel Corp. 

Peacock Alley 

1 Padanaram Road, Suite 146 

Oanbury 06810 

Tel: (203)792-8366 

TWX: 710-456-1199 

FLORIDA 

Intel Corp. 

1001 N.W. 62nd Street, Suite 406 

Ft. Lauderdale 33309 

Tel: (306)771-0600 

TWX: 510-956-9407 

Intel Corp 

5151 Adanson Street, Suite 203 

Orlando 32804 

Tel: (305)628-2393 

TWX: 810-853-9219 



U.S. AND CANADIAN SALES OFFICES 



FLORIDA (cent.) 

Pen-Tech Associates, Inc. 
201 S.E. 15th Terrace, Suite K 
Deerfield Beach 33441 
Tel: (305)421-4989 
Pen-Tech Associates, Inc. 
Ill So. Maitland Ave., Suite 202 
P.O. Box 1475 
Maitland 32751 
Tel: (305)645-3444 

GEORGIA 

Pen Tech Associates, Inc. 
Cherokee Center, Suite 21 
627 Cherokee Street 
Marietta 30060 
Tel: (404)424-1931 

ILLINOIS 

Intel Corp,* 

2250 Golf Road, Suite 815 
Rolling Meadows 60008 
Tel: (312)981-7200 
TWX: 910-651-5881 
Technical Representatives 
1502 North Lee Street 
Bloomington 61701 
Tel: (309)829-8080 

INDIANA 

Intel Corp. 

2212 Maplecrest Rd. 

Ft. Wayne 46815 

Tel: (219)493-2571 

Intel Corp. 

9101 Wesleyan Road 

Suite 204 

Indianapolis 46268 

Tel: (317)299-0623 

IOWA 

Technical Representatives, Inc. 

St. Andrews Building 

1930 St. Andrews Drive N.E. 

Cedar Rapids 52405 

Tel: (319)393-5510 

KANSAS 

Intel Corp. 

9393 W. 110th St., Ste. 265 

Overland Park 66210 

Tel: (913)642-8080 

Technical Representatives, Inc. 

8245 Nieman Road, Suite 100 

Lenexa 66214 

Tel: (913)888-0212, 3, & 4 

TWX: 910-749-6412 

Technical Representatives, Inc. 

360 N. Rock Road 

Suite 4 

Wichita 67206 

Tel: (316)681-0242 

KENTUCKY 

Lowry & Associates Inc. 
Lexington 40593 
Tel: (606)273-3771 

MARYLAND 

Intel Corp.* 
7257 Parkway Drive 
Hanover 21076 
Tel: (301)796-7500 
TWX: 710-862-1944 
Glen White Associates 
57 W. Timonium Road, Suite 307 
Timonium 21093 
Tel: (301)252-6360 
Mesa Inc. 

11900 Parkiawn Drive 
Rockville 20852 

Tel: Washington (301) 881-8430 
Baltimore (301) 792-0021 

MASSACHUSETTS 

Intel Corp.* 
27 Industrial Ave. 
Chelmsford 01824 
Tel: (617)667-8126 
TWX: 710-343-6333 
EMC Corp. 
381 Elliot Street 
Newton 02164 
Tel: (617)244-4740 
TWX 922531 

MICHIGAN 

Intel Corp.* 

26500 Northwestern Hwy. 
Suite 401 
Southfield 48075 
Tel: (313)353-0920 
TWX: 910-420-1212 
TELEX: 2 31143 
Lowry & Associates, Inc. 
135 W. North Street 
Suite 4 

Brighton 48116 
Tel: (313)227-7067 
Lowry & Associates, Inc. 
3902 Costa NE 
Grand Rapids 49505 
Tel: (616)363-9839 



MINNESOTA 

Intel Corp. 

7401 Metro Blvd. 

Suite 355 

Edina 55436 

Tel: (612)835-6722 

TWX: 910-576-2867 

Dytec North 

1821 University Ave. 

Room 163N 

St. Paul 55104 

Tel: (612)645-5816 

MISSOURI 

Intel Corp. 

502 Earth City Plaza 

Suite 121 

Earth City 63045 

Tel: (314)291-1990 

Technical Representatives, Inc. 

320 Brookes Drive, Suite 104 

Hazelwood 63042 

Tel: (314)731-5200 

TWX: 910-762-0618 

NEW JERSEY 

Intel Corp.* 
Raritan Plaza 
2nd Floor 
Raritan Center 



NEW MEXICO 

BFA Corporation 
P.O. Box 1237 
Las Cruces 88001 
Tel: (505)523-0601 
TWX: 910-983-0543 
BFA Corporation 
3705 Westerfield, N.E. 
Albuquerque 871 11 
Tel: (505)292-1212 
TWX: 910-989-1157 

NEW YORK 

Intel Corp.* 

350 Vanderbilt Motor Pkwy. 

Suite 402 

Hauppauge 11787 

Tel: (516)231-3300 

TWX: 510-227-6236 

Intel Corp. 

80 Washington St. 

Poughkeepsie 12601 

Tel: (914)473-2303 

TWX: 510-248-0060 

Intel Corp.* 

2255 Lyell Avenue 

Lower Floor East Suite 

Rochester 14606 

Tel: (716)254-6120 

TWX: 510-253-7391 

Measurement Technology, Inc. 

159 Northern Boulevard 

Great Neck 11021 

Tel: (516)482-3500 

T-Squared 

4054 Newcourt Avenue 

Syracuse 13206 

Tel: (315)463-8592 

TWX: 710-541-0554 

T-Squared 

2 E. Mam 

Victor 14564 

Tel: (716)924-9101 

TWX: 510-254-8542 

NORTH CAROLINA 

Intel Corp. 

154 Huffman Mill Rd. 
Burlington 27215 
Tel: (919)584-3631 
Pen-Tech Associates, Inc. 
1202 Eastchester Dr. 
Highpoint 27260 
Tel: (919)883-9125 
Glen White Associates 
4009 Barrett Dr. 
Raleigh 27609 
Tel: (919)787-7016 

OHIO 

Intel Corp.* 

6500 Poe Avenue 

Dayton 45415 

Tel: (513)890-5350 

TWX: 810-460-2528 

Intel Corp.* 

Chagrln-Brainard BIdg., No. 210 

28001 Chagrin Blvd. 

Cleveland 44122 

Tel: (216)464-2736 

Lowry & Associates Inc. 

1440 Snow Road 

Suite 216 

Cleveland 44134 

Tel: (216)398-0506 

Lowry & Associates, Inc. 

2194 Hewitt Avenue 

Dayton 46440 

Tel: (513)429-9040 



Lowry & Associates, Inc. 
Columbus 43224 
Tel: (614)436-2051 

OREGON 

Intel Corp. 

10700 S.W. Beaverton 
Hillsdale Highway 
Suite 324 
Beaverton 97005 
Tel: (503)641-8086 

PENNSYLVANIA 

Intel Corp.* 
275 Commerce Dr. 
200 Office Center 
Suite 300 

Fort Washington 19034 
Tel: (215)542-9444 
TWX: 510-661-2077 
Lowry & Associates, Inc. 
Seven Parkway Center 
Suite 455 
Pittsburgh 15520 
Tel: (412)922-5110 
Q.E.D. Electronics 
300 N. York Road 
Hatboro 19040 
Tel: (215)674-9600 

TEXAS 

Intel Corp.* 

2925 L.B.J. Freeway 

Suite 175 

Dallas 75234 

Tel: (214)241-9521 

TWX: 910-860-5487 

Intel Corp.* 

6420 Richmond Ave. 

Suite 280 

Houston 77057 

Tel: (713)784-3400 

Industrial Digital Systems Corp. 

5925 Sovereign 

Suite 101 

Houston 77036 

Tel: (713)988-9421 

Intel Corp. 

313 E. Anderson Lane 

Suite 314 

Austin 78752 

Tel: (512)454-3628 

VIRGINIA 

Glen White Associates 
Route 2, Box 193 
Charlottesville 22901 
Tel: (804)295-7686 
Glen White Associates 
P.O. Box 10186 
Lynchburg 24506 
Tel: (804)384-6920 
Glen White Associates 
Route 1, Box 322 
Colonial Beach 22442 
Tel: (804)224-7764 

WASHINGTON 

Intel Corp. 
Suite 114, BIdg. 3 
1603 116th Ave. N.E. 
Bellevue 98005 
Tel: (206)453-8086 

WISCONSIN 

Intel Corp. 

150 S. Sunnyslope Rd. 
Brookfield 53005 
Tel: (414)784-9060 

CANADA 

Intel Semiconductor Corp. 

Suite 233, Bell Mews 

39 Highway 7, Bells Corners 

Ottawa, Ontario K2H 6R2 

Tel: (613)829-9714 

TELEX: 053-4115 

Intel Semiconductor Corp. 

50 Galaxy Blvd. 

Unit 12 

Rexdale, Ontario 

M9W 4Y5 

Tel: (416) 676-2105 

TELEX: 06983574 

Multilek, Inc.* 

16 Grenfell Crescent 

Ottawa, Ontario K2G 0G3 

Tel: (613)226-2365 

TELEX: 053-4585 

Multilek, Inc. 

Toronto 

Tel: (416)246-4622 

Multilek, Inc. 

Montreal 

Tel: (614)481-1350 



'Field Application Location 



Intel 



3065 Bowers Avenue 
Santa Clara, California 95051 
Tel: (408)987-8080 
TWX: 910-338-0026 
TELEX: 34-6372 



INTERNATIONAL SALES AND MARKETING OFFICES 



INTEL'S' MARKETING OFFICES 



AUSTRALIA 

Intel Australia 

Suite 2, Level 15, North Point 

100 Miller Street 

North Sydney, NSW, 2060 

Tel: 450-847 

TELEX: AA 20097 

BELGIUM 



B-1160 Brussels 
Tel: (02)660 30 10 
TELEX: 24814 

DENMARK 

Intel Dennnark A/S* 
Lyngbyvej 32 2ncl Floor 
DK-2100 Copenhagen East 
Tel: (01)18 20 00 
TELEX: 19567 

FINLAND 

Intel Scandinavia 
Sentnerikuja 3 
SF • 00400 Helsinki 40 
Tel: (0)558531 
TELEX: 123 332 



FRANCE 

Intel Corporation, S.A.R.L.* 
5 Place de la Balance 
Silic 223 

94528 Rungis Cedex 
Tel: (01)687 22 21 
TELEX: 270475 

GERMANY 

Intel Semiconductor GmbH* 

Seidlstrasse 27 

8000 Muenchen 2 

Tel: (089)53 891 

TELEX: 523 177 

Intel Semiconductor GmbH 

Mainzer Strasse 75 

6200 Wiesbaden 1 

Tel: (06121)700874 

TELEX: 04186183 

Intel Semiconductor GmbH 

Wernerstrasse 67 

P.O. Box 1460 

7012 Fellbach 

Tel: (0711)580082 

TELEX: 7254826 

Intel Semiconductor GmbH 

HIndenburgstrasse 28/29 

3000 Hannover 1 

Tel: (0511)852051 

TELEX; 923625 



HONQ KONG 

Intel Trading Corporation 
99-105 Des Voeux Rd., Central 
18F, Unit B 
Hong Kong 
Tel: 5-450-847 
TELEX: 63869 

ISRAEL 



ITALY 

Intel Corporation Italia, S.p.A. 
Corso Sempione 39 
1-20145 Milano 
Tel: 2/34.93287 
TELEX: 311271 

JAPAN 

Intel Japan K.K.' 

Flower Hlil-Shinmachi East BIdg. 

1-23-9, Shinmachi, Setagaya-ku 

Tokyo 154 

Tel: (03)426-9261 

TELEX: 781-28426 



NETHERLANDS 

Intel Semiconductor B.V. 
Cometongebouw 
Westblaak 106 
3012 Km Rotterdam 
Tel: (10) 149122 
TELEX: 22283 

NORWAY 

Intel Norway A/S 
P.O. Box 158 
N-2040 

Klofta, Norway 
Tel: 47 2/981068 
TELEX: 18018 

SWEDfcN 

Intel Sweden A.B.* 
Box 20092 
Enighetsvagen, 5 
S-16120 Bromma 
Tel: (08)98 53 90 
TELEX: 12261 

SWITZERLAND 

Intel Semiconductor A.G. 
Forchastrasse 95 
CH 8032 Zurich 
Tel: 1-55 45 02 
TELEX: 557 89 ich ch 



UNITED KINGDOM 

Intel Corporation (U.K.) Ltd.* 
Broadfield House 

4 Between Towns Road 
Cowley, Oxford 0X4 3NB 
Tel: (0865) 77 14 31 
TELEX: 837203 

Intel Corporation (U.K.) Ltd. 

5 Hospital Street 
Nantwich, Cheshire CW5 5RE 
Tel: (0270)62 65 60 
TELEX: 36620 



INTERNATIONAL DISTRIBUTORS/REPRESENTATIVES 



ARGENTINA 

Micro SistemasS.A. 

9 De Julio 561 

Cordoba 

Tel: 54-51-32-880 

TELEX: 51837 BICCO 

AUSTRALIA 

A.J.F. Systems & Components Pty. Ltd. 

310 Queen Street 

Melbourne 

Victoria 3000 

Tel: 

TELEX: 

Warburton Franki 

Corporate Headquarters 

372 Eastern Valley Way 

Chatswood, New South Wales 2067 

Tel: 407-3261 

TELEX: AA 21299 

AUSTRIA 

Bacher Elektronlsche Geraete GmbH 

Rotenmulgasse 26 

A 1120 Vienna 

Tel: (0222)83 63 96 

TELEX: (01) 1532 

Rekirsch Elektronik Geraete GmbH 

Lichtensteinstrasse 97 

A1090 Vienna 

Tel: (222)347646 

TELEX: 74759 

BELGIUM 

Ineico Belgium S.A. 
Avenue Val Duf;hesse, 3 
B-1160 Brussels 
Tel: (02)660 00 12 
TELEX: 25441 

BRAZIL 

Icotron S.A. 

0511-Av. Mutinga3650 

6 Andar 

Pirituba-Sao Paulo 

Tel: 261-0211 

TELEX: (Oil) 222 ICO BR 

CHILE 

DIN 

Av. Vic. Mc kenna 204 

Casilla 6055 

Santiago 

Tel: 227 564 

TELEX: 3520003 

CHINA 

CM. Technologies 
525 University Avenue 
Suite A-40 
Palo Alto, CA 94301 

COLOMBIA 

International Computer Machines 
Adpo. Aereo 19403 
Bogota 1 
Tel: 232-6635 
TELEX: 43439 

CYPRUS 

Cyprus Eltrom Electronics 

P.O. Box 5393 

Nicosia 

Tel: 21-27982 



DENMARK 

STL-Lyngso Komponent A/S 

Ostmarken 4 

DK-2860 Soborg 

Tel: (01)67 00 77 

TELEX: 22990 

Scandinavian Semiconductor 

Supply A/S 

Nannasgade 18 

DK-2200 Copenhagen 

Tel: (01)83 60 90 

TELEX: 19037 

FINLAND 

Oy Fintronic AB 

Melkonkatu 24 A 

SF-00210 

Helsinki 21 

Tel: 0-692 6022 

TELEX: 124 224 Ftron SF 

FRANCE 

Celdls S.A.* 

53, Rue Charles Frerot 

94250 Gentilly 

Tel: (1) 581 00 20 

TELEX: 200 485 

Feutrier 

Rue des Trois Glorleuses 

F-42270 St. Priest-en-Jarez 

Tel: 167 7746733 

Metrologie* 

La Tour d'Asnieres 

4, Avenue Laurent Cely 

92606- Asnieres 

Tel: 791 44 44 

TELEX: 611 448 

Tekelec Airtronic* 

Cite des Bruyeres 

Rue Carle Vernet 

92310 Sevres 

Tel: (1)534 75 35 

TELEX: 204552 

GERMANY 

Electronic 2000 Vertriebs GmbH 

Neumarkter Strasse 75 

D-8000 Munich 80 

Tel: (089)434061 

TELEX: 522561 

Jermyn GmbH 

Postfaoh 1180 

D-6277 Camberg 

Tel: (06434)231 

TELEX: 484426 

Kontron Elektronik GmbH 

Breslauerstrasse 2 

8057 Eching B 

D-8000 Munich 

Tel: (89)319.011 

TELEX: 522122 

Neye Enatechnik GmbH 

Schillerstrasse 14 

D-2085 Quickborn-Hamburg 

Tel: (04106)6121 

TELEX: 02-13590 

GREECE 

American Technical Enterprises 
P.O. Box 156 
Athens 

Tel: 30-1-8811271 
30-1-8219470 



HONQ KONG 

Schmidt & Co. 

28/F Wing on Center 

Connaught Road 

Hong Kong 

Tel: 5-455-644 

TELEX: 74766 Schmc Hx 

INDIA 

Micronic Devices 

104/109C, Nirmal Industrial Estate 

Sion (E) 

Bombay 400022, India 

Tel: 486-170 

TELEX: 011-5947 MDEV IN 

ISRAEL 

Eastronics Ltd.* 
11 Rozanis Street 
P.O. Box 39300 



ITALY 

Eledra 38 S.P.A. * 

Viale Elvezia, 16 

I 20154 Milan 

Tel- (02)34.93.041-31.85.441 

TELEX: 332332 

JAPAN 

Asahi Electronics Co. Ltd. 

KMM BIdg. Room 407 

2-14-1 Asano, Kokura 

Kita-Ku, Kitokyushu City 802 

Tel: (093)511-6471 

TELEX: AECKY 7126-16 

Hamilton-Avnet Electronics Japan Ltd. 

YU and YOU BIdg. 1-4 Horidome-Cho 

Nihonbashi 

Tel: (03)662-9911 

TELEX: 2523774 

Nippon Micro Computer Co. Ltd. 

Mutsumi BIdg. 4-5-21 Kojimachi 

Chlyoda-ku,' Tokyo 102 

Tel: (03)230-0041 

Ryoyo Electric Corp. 

Konwa BIdg. 

1-12-22, Tsukiji, 1-Chome 

Chuo-Ku, Tokyo 104 

Tel: (03)543-7711 

Tokyo Electron Ltd. 

No. 1 Higashikata-Machi 

Midori-Ku, Yokohama 226 

Tel: (045)471-8811 

TELEX: 781-4473 

KOREA 

Koram Digital 

Room 411 Ahil BIdg. 

49-4 2-GA Hoehyun-Dong 

Chung-Ku Seoul 

Tel: 23-8123 

TELEX: K23542 HANSINT 

Leewood International, Inc. 

C.P.O. Box 4046 

112-25, Sokong-Dong 

Chung-Ku, Seoul 100 

Tel: 28-5927 

CABLE: "LEEWOOD" Seoul 



NETHERLANDS 

Ineico Nether. Comp. Sys. BV 

Turfstekerstraat 63 

Aalsmeer 1431 D 

Tel: (2977)28855 

TELEX: 14693 

Koning & Hartman 

Koperwerf 30 

2544 EN Den Haag 

Tel: (70)210.101 

TELEX: 31528 

NEW ZEALAND 

W. K. McLean Ltd. 

P.O. Box 18-065 

Glenn Innes, Auckland, 6 

Tel: 587-037 

TELEX: NZ2763 KOSFY 

NORWAY 

Nordisk Elektronik (Norge) A/S 
Postofflce Box 122 
Smedsvingen 4 
1364 Hvalstad 
Tel: 02 78 62 10 
TELEX: 17546 

PORTUGAL 

Ditram 

Componentes E Electronica LDA 

Av. Miguel Bombarda, 133 

Lisboa 1 

Tel: (19)545313 

TELEX: 14347 GESPIC 

SINGAPORE 

General Engineers Associates 

BIk 3, 1003-1008, 10th Floor 

P.S.A. Multi-Storey Complex 

Telok Blangah/Pasir Panjang 

Singapore 5 

Tel: 271-3163 

TELEX: RS23987 GENERCO 

SOUTH AFRICA 

Electronic Building Elements 

Pine Square 

18th Street 

Hazelwood, Pretoria 0001 

Tel: 789 221 

TELEX: 30181SA 

SPAIN 

Interface 

Av. Generalisimo 51 9° 

E-Madrid 16 

Tel: 456 3151 

ITT SESA 

Miguel Angel 16 

Madrid 10 

Tel: (1)4190957 

TELEX: 27707/27461 

SWEDEN 

AB Gosta Backstrom 
Box 12009 
10221 Stockholm 
Tel: (08) 541 080 
TELEX: 10135 
Nordisk Electronik AB 
Box 27301 
S-10254 Stockholm 
Tel: (08)635040 
TELEX: 10547 



SWITZERLAND 

Industrade AG 
Gemsenstrasse 2 
Postcheck 80 -21190 
CH-8021 Zurich 
Tel: (01)60 22 30 
TELEX: 56788 

TAIWAN 

Taiwan Automation Co.* 

3d Floor #75, Section 4 

Nanking East Road 

Taipei 

Tel: 771-0940 

TELEX: 11942 TAIAUTO 

TURKEY 

TurkeIek Electronics 
Apapurk Boulevard 169 



UNITED KINGDOM 

Comway Microsystems Ltd. 

Market Street 

68-Bracknell, Berkshire 

Tel: 44-34451654 

G.E.C. Semiconductors Ltd. 

East Lane 

North Wembley 

Middlesex HA9 7PP 

Tel: (01)904-9303/908-4111 

TELEX: 28817 

Jermyn Industries 

Vestry Estate 

Sevenoaks, Kent 

Tel: (0732)501.44 

TELEX: 95142 

Rapid Recall, Ltd. 

6Soho Mills Ind. Park 

Woburn Green 

Bucks, England 

Tel: (6285)24961 

TELEX: 849439 

Sintrom Electronics Ltd.* 

Arkwright Road 2 

Reading, Berkshire RG2 OLS 

Tel: (0734)85464 

TELEX: 847395 

VENEZUELA 

Componentes y Circuitos 

Electronicos TTLCA CA. 
Apartado 3223 
Caracas 101 
Tel: 718-100 
TELEX: 21795 TELETIPOS 



•Field Application Location 



Intel Corporation 
3065 Bowers Avenue 
Santa Clara, CA 95051 
(408) 987-8080 



Intel Corporation 

Rue du Moulin k Papier 51, Boite 1, 

B-1160 Brussels, Belgium 



Intel Corporation 
Flower Hill-Shinmachi East BIdg. 
1-23-9, Shinmachi, Setagayu-ku 
Tokyo 154, Japan 



